- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
某软件的磁盘缝隙擦除功能的具体实现~
2009年12月16日 20:54
所谓磁盘缝隙擦除,就是将磁盘的空闲空间全部写0,这样可以抹掉一些敏感信息(比如上网记录),对保护隐私比较重要。这几天在升级我的《上网记录深度擦除工具》的过程中,发现有不少信息就隐藏在空闲空间里,因此想自己实现这一功能。折腾中发现某软件已经有了该功能,无奈加壳(PEID查不出来,偶脱壳水平又比较菜),于是黑盒之~运行软件擦除目标分区空闲空间,速度还可以接受,擦除完之后目标分区根目录下多出一FileChk文件夹。拿出WinHex打开刚开擦除的分区看了一下,秘密出来了:原来就是计算分区剩余空间的大小,然后依次建立大小为10M,内容全为0的文件,直至分区满为止,用另类的方法实现了剩余空间填0。然后再删除上面建立的那些文件,就搞定了~~再次实验,这次直接抓个现行~~非常简单的方法,纯ring3,用的API也没超过10个,GetDiskFreeSpace,CreateFile,SetEndOfFile,CloseHandle~~直接贴个代码:BOOL CreateEmptyFile(char *szFilePath,DWORD FileSize){DWORD dwnewOffset=0;HANDLE hFile=CreateFile(szFilePath,?? GENERIC_READ|GENERIC_WRITE,?? FILE_SHARE_READ,?? NULL,?? CREATE_ALWAYS,?? FILE_ATTRIBUTE_NORMAL,?? NULL);if (hFile==INVALID_HANDLE_VALUE){??return FALSE;}dwnewOffset=SetFilePointer(hFile,FileSize,NULL,FILE_BEGIN);if (dwnewOffset!=FileSize){?? CloseHandle(hFile);??return FALSE;}SetEndOfFile(hFile);CloseHandle(hFile);return TRUE;}我靠,我以为至少得发个FSCTL_GET_VOLUME_BITMAP然后自己来搞定呢还是用这种简单的方法吧,完全标准API,啥也不用多考虑,全部由系统给你搞定,太Easy了~
文档评论(0)