⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 redlofkillerdlg.h

📁 一个可以查杀Redlof病毒的小工具,界面玩具地很,但实现具一定参考价值
💻 H
字号:
// RedLofKillerDlg.h : header file
//

#if !defined(AFX_REDLOFKILLERDLG_H__04D8FDA2_CD63_4903_879B_7615DD6B6AC6__INCLUDED_)
#define AFX_REDLOFKILLERDLG_H__04D8FDA2_CD63_4903_879B_7615DD6B6AC6__INCLUDED_

#if _MSC_VER > 1000
#pragma once
#endif // _MSC_VER > 1000

/////////////////////////////////////////////////////////////////////////////
// CRedLofKillerDlg dialog
#define WM_CONFIRM			WM_USER + 1
class CRedLofKillerDlg : public CDialog
{
friend class	CConfirmDlg;
//公有静态方法定义
public:
	static int CALLBACK BrowseCallBack(HWND hWnd, UINT uMsg, LPARAM lParam, LPARAM lpData);
	static DWORD WINAPI ScanThread(LPVOID lpParam);
	enum {SCAN_OK,SCAN_FAILED};
	enum {VIRUS_DEL, VIRUS_CLEAR, VIRUS_IGNORE};
// Construction
public:
	CRedLofKillerDlg(CWnd* pParent = NULL);	// standard constructor

// Dialog Data
	//{{AFX_DATA(CRedLofKillerDlg)
	enum { IDD = IDD_REDLOFKILLER_DIALOG };
	CListBox	m_lstInfected;
	CStatic	m_stScanProgress;
	//}}AFX_DATA

	// ClassWizard generated virtual function overrides
	//{{AFX_VIRTUAL(CRedLofKillerDlg)
	protected:
	virtual void DoDataExchange(CDataExchange* pDX);	// DDX/DDV support
	//}}AFX_VIRTUAL

// Implementation
protected:
	HICON m_hIcon;

	// Generated message map functions
	//{{AFX_MSG(CRedLofKillerDlg)
	virtual BOOL OnInitDialog();
	afx_msg void OnSysCommand(UINT nID, LPARAM lParam);
	afx_msg void OnPaint();
	afx_msg HCURSOR OnQueryDragIcon();
	afx_msg void OnSelectFolder();
	afx_msg void OnScanStart();
	afx_msg void OnScanStop();
	//}}AFX_MSG
	afx_msg void OnConfirm(WPARAM wParam,LPARAM lParam);
	DECLARE_MESSAGE_MAP()
//自定义私有函数
private:
	//对指定文件夹下的所有文件进行扫描,并杀毒
	int ScanFolder(CString& argFolder);
	//对指定文件进行查杀
	int ScanFile(CString& argFile);
	int InitApp();
	//初始化计数器
	int InitCnt();
//自定义私有成员变量
private:
	CString  m_strFolderScan;  // 存储将要被扫描的文件夹的名称
	CArray<CString,CString> m_strExt; //存储可能被感染的文件类型的扩展名
	int m_nExtCnt; //可能被感染的文件扩展名的类型数
  char m_lpVirusFlag[MAX_PATH];
	char m_lpVirusExecStart[50];    //病毒执行码的起始标志字符串
	char m_lpVirusExecEnd[50];			//病毒执行码的结束标志字符串
	int m_handleType;      //对被感染文件的处理方式
	BOOL m_bUseToAll;      //标志变量,决定是否将上一次的处理方式适用于所有对象
	int m_nScanTotalCount;  //扫描的所有文件的个数
  int m_nInfectedCnt;     //被感染的文件个数
	int m_nKilledCnt;       //被清除病毒的文件个数
	int m_nDelCnt;					//被删除的带毒文件个数
	int m_nIgnoreCnt;				//被忽略处理的带毒文件个数 
	HANDLE m_hThreadScan;		//扫描线程的句柄 
	BOOL m_bExitScan;				//标识退出线程的标志变量
};

//{{AFX_INSERT_LOCATION}}
// Microsoft Visual C++ will insert additional declarations immediately before the previous line.

#endif // !defined(AFX_REDLOFKILLERDLG_H__04D8FDA2_CD63_4903_879B_7615DD6B6AC6__INCLUDED_)

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -