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;
}