鱼C论坛

 找回密码
 立即注册
查看: 3172|回复: 1

[技术交流] 文件粉碎机

[复制链接]
发表于 2018-5-6 11:28:12 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
小弟最近学习了WindowsSDK程序设计,学到了文件操作部分,想复习一下之前的知识,
这个文件粉碎机是一个2.0版本,1.0版本的文件粉碎机不人性化,要是想删除运行中的快捷方式的话还要让用户手动输入快捷方式所指向的真正的目标路径的文件名,所以2.0版本小弟还从网上查资料找到了一个IShellLink中的GetPath,来进行寻找目标的绝对地址,然后再分割出来进程中的名字。

主要思路就是一个文件的删除函数DeleteFile的应用,要是无法恢复数据的删除就要进行对要删除的文件进行覆写,程序中是覆写三遍,要是有快捷方式或者是exe运行的情况下就要先kill掉进程,然后再删除。

这个是一个CUI,有点丑陋,但是小弟花了一晚上写1.0,然后花了一上午写2.0,要是有bug希望指出,同时小弟的水平还有待提高,希望大神们多多指正

运行程序是一个C++文件,因为里面有个函数是获取快捷方式目标的绝对地址的,同时在设置项目属性的时候要选择多字符集
[hide]#include <windows.h>
#include <tlhelp32.h>
#include <stdlib.h>
#include <stdio.h>
#include <ShlObj.h>                        //其中含有获取快捷方式路径的函数
#include <sys/stat.h>                //获取文件相关操作的一些函数


//获取快捷方式的目标路径
BOOL GetShellPath(CHAR *src, CHAR *ShellPath){
        BOOL bRet = FALSE;

        CoInitialize(NULL); //初始化com接口
        IShellLink *psl = NULL;

        //创建COM接口,IShellLink对象创建
        HRESULT hr = CoCreateInstance(CLSID_ShellLink, NULL, CLSCTX_INPROC_SERVER, IID_IShellLink, (LPVOID*)&psl);

        if (SUCCEEDED(hr)){
                IPersistFile *ppf;
                hr = psl->QueryInterface(IID_IPersistFile, (LPVOID*)&ppf);
                if (SUCCEEDED(hr)){
                        WCHAR wsz[MAX_PATH] = { 0 };
                        MultiByteToWideChar(CP_ACP, 0, src, -1, wsz, MAX_PATH);
                        hr = ppf->Load(wsz, STGM_READ);//加载文件
                        if (SUCCEEDED(hr)){
                                WIN32_FIND_DATA wfd;
                                psl->GetPath(ShellPath, MAX_PATH, (WIN32_FIND_DATA*)&wfd, SLGP_SHORTPATH);     //获取目标路径

                                bRet = TRUE;
                        }
                        ppf->Release();
                }
                psl->Release();
        }
        CoUninitialize();
        return bRet;
}

void GetProcessFileName(CHAR *szShellPath, CHAR *szTargetExeFile){
        CHAR szExtension[MAX_PATH];                //文件后缀
        CHAR szFileName[MAX_PATH];                //文件名称

        _splitpath(szShellPath, NULL, NULL, szFileName, szExtension);
        lstrcat(szTargetExeFile, szFileName);
        lstrcat(szTargetExeFile, szExtension);
        //这样就获取到了进程中的要删除快捷方式对应的进程名字
        printf("\n\n\n%s\n\n\n", szTargetExeFile);
}



DWORD GetProcessID(LPSTR szProcessName){
        DWORD dwProcessId = 0;                // 用于记录进程的ID号
        PROCESSENTRY32 pe32;
        pe32.dwSize = sizeof(pe32);

        HANDLE hProcessSnap = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);
        if (hProcessSnap == INVALID_HANDLE_VALUE){
                printf("CreateToolhelp32Snapshot调用失败:%d\n", GetLastError());
                return -1;
        }
        else{
                BOOL bMore = Process32First(hProcessSnap, &pe32);
                while (bMore){
                        if (lstrcmp(pe32.szExeFile, szProcessName) == 0){
                                dwProcessId = pe32.th32ProcessID;
                        }
                        bMore = Process32Next(hProcessSnap, &pe32);
                }
                CloseHandle(hProcessSnap);
        }
        return dwProcessId;
}


DWORD KillProcess(LPSTR szProcessName){
        if (GetProcessID(szProcessName) != 0){                //判断进程是否存在
                HANDLE hProcessToKill = OpenProcess(PROCESS_ALL_ACCESS, FALSE, GetProcessID(szProcessName));
                if (hProcessToKill){
                        TerminateProcess(hProcessToKill, 0);
                }
                CloseHandle(hProcessToKill);
        }
        return 0;
}


DWORD DeleteTargetFile(LPSTR szDeleteFile){
        DWORD dwChoose = MessageBox(NULL,
                TEXT("请问是否要完全清除数据,用专业恢复数据软件也没有办法恢复!"),
                TEXT("警告"),
                MB_OKCANCEL | MB_ICONEXCLAMATION);


        if (dwChoose == IDOK){
                CHAR *buffer[1280] = { "这个文件恢复不了成原先的状态",
                        "数据无价,早知今日,何必当初",
                        "西瓜,苹果,香蕉,菠萝" };

                HANDLE hFileWrite = CreateFile(szDeleteFile,
                        GENERIC_WRITE,
                        0,
                        NULL,
                        OPEN_ALWAYS,
                        FILE_ATTRIBUTE_NORMAL,
                        NULL);

                if (hFileWrite == INVALID_HANDLE_VALUE){
                        printf("文件写入句柄创建错误:%d\n", GetLastError());
                        return -1;
                }

                DWORD dwWriteDataSize;

                for (int i = 0; i < 3; i++){
                        printf("进行第%d次覆写\n", i + 1);
                        if (!WriteFile(hFileWrite, buffer[i], lstrlen(buffer[i]), &dwWriteDataSize, NULL)){
                                printf("写入失败:%d\n", GetLastError());
                                return -1;
                        }
                        else{
                                printf("写入%d字节\n", dwWriteDataSize);
                        }
                }
                CloseHandle(hFileWrite);                //关闭写入文件的句柄
                DeleteFile(szDeleteFile);                //删除文件
                MessageBox(NULL, "彻底删除文件成功", "提示", MB_OK);
        }
        else{
                if (MessageBox(NULL,
                        "这个数据是可以日后依靠专业的数据恢复软件进行恢复的,但是会直接从您的电脑上删除,不放入回收站,是否继续?",
                        "提示",
                        MB_OKCANCEL | MB_ICONQUESTION) == IDOK){
                        DeleteFile(szDeleteFile);
                        MessageBox(NULL, "删除成功", "提示", MB_OK);
                }
        }
        return 0;
}



int main(int argc, char *argv[]){
        CHAR* szDeleteFile = (CHAR*)malloc(sizeof(CHAR)*MAX_PATH);
        DWORD dwChoose = MessageBox(NULL, "请问您删除的是快捷方式或者.exe文件么", "提示", MB_OKCANCEL | MB_ICONQUESTION);
        if (dwChoose == IDOK){                                                                                //如果是快捷方式或者.exe文件
                if (MessageBox(NULL, "请问您要删除的是快捷方式么?", "提示", MB_OKCANCEL | MB_ICONQUESTION) == IDOK){
                        printf("请输入您要删除的快捷方式的绝对路径:");
                        scanf("%s", szDeleteFile);
                        CHAR* szShellPath = (CHAR*)malloc(sizeof(CHAR)*MAX_PATH);
                        if (GetShellPath(szDeleteFile, szShellPath)){                //获取快捷方式对应的目标路径
                                CHAR* szTargetExeFile = (CHAR*)malloc(sizeof(CHAR)*MAX_PATH);
                                lstrcpy(szTargetExeFile, "");
                                GetProcessFileName(szShellPath, szTargetExeFile);
                                KillProcess(szTargetExeFile);                                        //终止要删除的文件的进程
                                DeleteTargetFile(szDeleteFile);                                        //删除快捷方式

                                //释放内存
                                free(szTargetExeFile);
                                free(szShellPath);
                                free(szDeleteFile);
                        }
                }
                else{

                        CHAR* szTargetExeFile = (CHAR*)malloc(sizeof(CHAR)*MAX_PATH);
                        lstrcpy(szTargetExeFile, "");
                        printf("请输入您要删除.exe文件的绝对路径:");
                        scanf("%s", szDeleteFile);

                        GetProcessFileName(szDeleteFile, szTargetExeFile);
                        KillProcess(szTargetExeFile);                        //终止进程
                        DeleteTargetFile(szDeleteFile);
                        free(szDeleteFile);
                        free(szTargetExeFile);
                }
        }
        else{
                printf("请输入您要删除文件的绝对路径:");
                scanf("%s", szDeleteFile);
                DeleteTargetFile(szDeleteFile);
        }
        return 0;
}





[/hide]
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2018-5-6 12:06:14 | 显示全部楼层
whx2008 发表于 2018-5-6 11:47
你那个是怎么回事?应该是这样写的:
注:为了防止真的隐藏,我在外面弄了一个代码形式。

我也不知道怎么弄那个隐藏,下次还是不搞这个了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-23 21:09

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表