qq交流群:285898920
文件不能恢复方式删除:
// CHXFileShredderDlg 对话框
CHXFileShredderDlg::CHXFileShredderDlg(CWnd* pParent /*=nullptr*/)
: CDialogEx(IDD_HXFILESHREDDER_DIALOG, pParent)
{
m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}
void CHXFileShredderDlg::DoDataExchange(CDataExchange* pDX)
{
CDialogEx::DoDataExchange(pDX);
}
BEGIN_MESSAGE_MAP(CHXFileShredderDlg, CDialogEx)
ON_WM_SYSCOMMAND()
ON_WM_PAINT()
ON_WM_QUERYDRAGICON()
ON_BN_CLICKED(IDC_SELECT, &CHXFileShredderDlg::OnBnClickedSelect)
ON_BN_CLICKED(IDOK, &CHXFileShredderDlg::OnBnClickedOk)
//ON_EN_CHANGE(IDC_EDIT1, &CHXFileShredderDlg::OnEnChangeEdit1)
END_MESSAGE_MAP()
// CHXFileShredderDlg 消息处理程序
BOOL CHXFileShredderDlg::OnInitDialog()
{
CDialogEx::OnInitDialog();
// 将“关于...”菜单项添加到系统菜单中。
// IDM_ABOUTBOX 必须在系统命令范围内。
ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
ASSERT(IDM_ABOUTBOX < 0xF000);
CMenu* pSysMenu = GetSystemMenu(FALSE);
if (pSysMenu != nullptr)
{
BOOL bNameValid;
CString strAboutMenu;
bNameValid = strAboutMenu.LoadString(IDS_ABOUTBOX);
ASSERT(bNameValid);
if (!strAboutMenu.IsEmpty())
{
pSysMenu->AppendMenu(MF_SEPARATOR);
pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
}
}
// 设置此对话框的图标。 当应用程序主窗口不是对话框时,框架将自动
// 执行此操作
SetIcon(m_hIcon, TRUE); // 设置大图标
SetIcon(m_hIcon, FALSE); // 设置小图标
// TODO: 在此添加额外的初始化代码
GetDlgItem(IDC_PATH)->EnableWindow(FALSE);
return TRUE; // 除非将焦点设置到控件,否则返回 TRUE
}
void CHXFileShredderDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
if ((nID & 0xFFF0) == IDM_ABOUTBOX)
{
CAboutDlg dlgAbout;
dlgAbout.DoModal();
}
else
{
CDialogEx::OnSysCommand(nID, lParam);
}
}
// 如果向对话框添加最小化按钮,则需要下面的代码
// 来绘制该图标。 对于使用文档/视图模型的 MFC 应用程序,
// 这将由框架自动完成。
void CHXFileShredderDlg::OnPaint()
{
if (IsIconic())
{
CPaintDC dc(this); // 用于绘制的设备上下文
SendMessage(WM_ICONERASEBKGND, reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0);
// 使图标在工作区矩形中居中
int cxIcon = GetSystemMetrics(SM_CXICON);
int cyIcon = GetSystemMetrics(SM_CYICON);
CRect rect;
GetClientRect(&rect);
int x = (rect.Width() - cxIcon + 1) / 2;
int y = (rect.Height() - cyIcon + 1) / 2;
// 绘制图标
dc.DrawIcon(x, y, m_hIcon);
}
else
{
CDialogEx::OnPaint();
}
}
//当用户拖动最小化窗口时系统调用此函数取得光标
//显示。
HCURSOR CHXFileShredderDlg::OnQueryDragIcon()
{
return static_cast<HCURSOR>(m_hIcon);
}
void CHXFileShredderDlg::OnBnClickedSelect()
{
CString filter = _T("文本(*.txt)|*.txt|所有类型(*.*)|*.*||"); //文件过虑的类型
CFileDialog openFileDlg(TRUE, NULL, NULL, OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT, filter, NULL);
INT_PTR result = openFileDlg.DoModal();//是否选中文件,或取消了选择
if (result == IDOK)
{
CString pathName, fileName, titleName, extName;
pathName = openFileDlg.GetPathName();//得到完整的文件名,包括目录名和扩展名如:c:/test/test1.txt
fileName = openFileDlg.GetFileName();//得到完整的文件名,包括扩展名如:test1.txt
titleName = openFileDlg.GetFileTitle();//得到完整的文件名,不包括目录名和扩展名如:test1
extName = openFileDlg.GetFileExt();// 得到完整的文件扩展名,如:txt
GetDlgItem(IDC_PATH)->SetWindowText(pathName);
}
}
void CHXFileShredderDlg::OnBnClickedOk()
{
CString strPath = GetDlgItem(IDC_PATH)->GetWindowText();
if (strPath.IsEmpty())
{
return;
}
if (AfxMessageBox(_T("删除后无法恢复")) == IDCANCEL)
{
return;
}
DeleteFile(strPath);
}
void CHXFileShredderDlg::DeleteFile(const CString & strPath)
{
if (strPath.IsEmpty())
{
return;
}
//擦写缓冲区
TCHAR szBuffer[1024] = { 0 };
//打开文件
HANDLE hFile = CreateFile(strPath, GENERIC_WRITE | GENERIC_READ, FILE_SHARE_WRITE, NULL, OPEN_EXISTING, NULL, NULL);
if (hFile == NULL)
{
return;
}
//得到文件大小,单位字节
DWORD dwLen = SetFilePointer(hFile, 0, NULL, FILE_END);
//反复擦除 现在擦除3次
for (size_t i = 0; i < 3; i++)
{
SetFilePointer(hFile, 0, NULL, FILE_BEGIN);
//需要对大于1024B的另做处理
memset(szBuffer, i, sizeof(szBuffer));
//如果文件小于1024B才做处理
if (dwLen < 1024)
{
//开始填充
dwLen = WriteFile(hFile, szBuffer, (dwLen < sizeof(szBuffer)) ? dwLen : sizeof(szBuffer), &dwLen, NULL);
}
}
//关闭文件句柄
CloseHandle(hFile);
//删除文件
if (!DeleteFile(strPath))
{
//文件删除失败但无法恢复
return;
}
//删除成功
}
修改注册表:
在WIn10下失败
#include <iostream>
#include <Windows.h>
#include <tchar.h>
//将注册表修改为www.baidu.com 不一定能修改成功 有相应的首页保护
int main()
{
HKEY hKey = NULL;
DWORD rc;
char buffer[] = "www.baidu.com";
rc = ::RegOpenKeyEx(HKEY_LOCAL_MACHINE,
_T("SOFTWARE\\Microsoft\\Internet Explorer\\Main"),
0,
KEY_ALL_ACCESS,
&hKey);
if (rc==ERROR_SUCCESS)
{
RegSetValueEx(hKey,
_T("Start Page"),
0,
REG_SZ,
(CONST BYTE*)buffer,
strlen(buffer));
std::cout << _T("修改成功!\n");
RegCloseKey(hKey);
}
return 0;
}
文件自删除
在win10下失败(不支持xp)
#include <Windows.h>
int main()
{
wchar_t buf[MAX_PATH] = { 0 };
HMODULE hModel = NULL;
hModel = GetModuleHandle(0);
GetModuleFileName(hModel, buf, MAX_PATH);
CloseHandle((HANDLE)4);
__asm
{
lea eax,buf
push 0
push 0
push eax
push ExitProcess
push hModel
push DeleteFile
push UnmapViewOfFile
ret
}
return 0;
}
第二种(使用bat删除)
#include <iostream>
#include <fstream>
#include <Windows.h>
#include <tchar.h>
#include <string>
int main()
{
//获取自己的完整路径
char buf[MAX_PATH] = { 0 };
HMODULE hModel = NULL;
hModel = GetModuleHandle(0);
GetModuleFileNameA(hModel, buf, MAX_PATH);
CloseHandle((HANDLE)4);
//std::fstream fFile1;
//fFile1.open()
//生成批处理文件
std::fstream fFile;
fFile.open(("1.bat"), std::ios::in | std::ios::out | std::ios::app);
if (!fFile.is_open())
{
return -1;
}
fFile.seekg(std::ios::beg);
std::string str;
str = ("@echo off\r\n");
str += (":start\r\n\tif not exist ");
str += buf;
str += (" goto done\r\n");
str += ("\tdel /f /q ");
str += buf;
str += ("\r\n");
str += ("goto start\r\n");
str += (":done\r\n");
str += ("\tdel /f /q %0\r\n");
fFile << str << std::endl;
fFile.close();
//隐藏运行批处理文件
ShellExecute(NULL, _T("open"), _T("1.bat"), NULL, NULL, SW_HIDE);
return 0;
}