分享
 
 
 

WIN9X下查找隐藏进程实现方法

王朝system·作者佚名  2008-05-19
窄屏简体版  字體: |||超大  

在WIN 9X下一些黑客工具利用了未公开的API函数实现了隐藏自身,不在任务列表中出现的功能,要把它们找出来,同样也需要用到未公开的TOOLHELP32系列函数。因操作系统的不同NT下遍历进程则用PSAPI函数来实现,下面给出完整实列。

Process.h

//----------------------------

#ifndef Unit1H

#define Unit1H

//----------------------------

#include

#include

#include

#include

#define TH32CS_SNAPPROCESS 0x00000002 //快照进程

#define PROCESS_HANDLE_NAME 255

//---------------------------------------------------------------------------

typedef struct tagPROCESSENTRY32 //自定义TOOLHELP32结构

{

DWORD dwSize;

DWORD cntUsage;

DWORD th32ProcessID; //进程ID

DWORD th32DefaultHeapID;

DWORD th32ModuleID;

DWORD cntThreads;

DWORD th32ParentProcessID;

LONG pcPriClassBase;

DWORD dwFlags;

TCHAR szExeFile[MAX_PATH]; //进程文件名

} PROCESSENTRY32;

typedef PROCESSENTRY32 * LPPROCESSENTRY32;

//以下定义要从KERENL32.DLL中取出的TOOLHELP32函数的函数指针

HANDLE (WINAPI *CreateToolhelp32Snapshot)(DWORD dwFlags,DWORD th32PD);

BOOL (WINAPI *Process32First)(HANDLE hSnapshot,LPPROCESSENTRY32 pe);

BOOL (WINAPI *Process32Next)(HANDLE hSnapshot,LPPROCESSENTRY32 pe);

//以下定义要从PSAPI.DLL中取出函数的函数指针

BOOL (WINAPI *EnumProcesses)(DWORD* lpidProcess,DWORD cb,DWORD *cbNeeded);

DWORD (WINAPI *GetModuleFileNameExA)(HANDLE hProcess,HMODULE hModule,LPTSTR lpstrFileName,DWORD nSize);

class TForm1 : public TForm

{

__published: // IDE-managed Components

TButton *FindAllProcessFileName;

TListBox *ListBox1;

void __fastcall FindAllProcessFileNameClick(TObject *Sender);

void __fastcall FormResize(TObject *Sender);

void __fastcall Button1Click(TObject *Sender);

void __fastcall ListBox1Click(TObject *Sender);

private: // User declarations

public: // User declarations

__fastcall TForm1(TComponent* Owner);

};

//---------------------------------------------------------------------------

extern PACKAGE TForm1 *Form1;

//---------------------------------------------------------------------------

#endif

Process.cpp

//---------------------------------------------------------------------------

#include

#pragma hdrstop

#include "Unit1.h"

//---------------------------------------------------------------------------

#pragma package(smart_init)

#pragma resource "*.dfm"

TForm1 *Form1;

//定义变量

HANDLE process[255];

PROCESSENTRY32 p32;

DWORD process_ids[255];

DWORD num_processes;

TCHAR file_name[MAX_PATH];

TCHAR class_name[MAX_PATH];

unsigned i;

//---------------------------------------------------------------------------

//初始化TOOLHELP32

BOOL InitToolHelp32()

{

//动态调用

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

if(DLLinst)

{

//取各函数在KERNEL32中的地址

CreateToolhelp32Snapshot=(HANDLE(WINAPI *)(DWORD dwFlags,DWORD th32PD))

GetProcAddress(DLLinst,"CreateToolhelp32Snapshot");

Process32First=(BOOL(WINAPI *)(HANDLE hSnapshot,LPPROCESSENTRY32 pe))

GetProcAddress(DLLinst,"Process32First");

Process32Next=(BOOL(WINAPI *)(HANDLE hSnapshot,LPPROCESSENTRY32 pe))

GetProcAddress(DLLinst,"Process32Next");

if((!(UINT)CreateToolhelp32Snapshot)||(!(UINT)Process32First)||(!(UINT)Process32Next))

return FALSE;

else

return TRUE;

}

return FALSE;

}

//初始化PSAPI

BOOL InitPSAPI()

{

HINSTANCE PSAPI=LoadLibrary("PSAPI.DLL");

if(NULL==PSAPI)

return FALSE;

EnumProcesses=(BOOL(WINAPI *)(DWORD* lpidProcess,DWORD cb,DWORD *cbNeeded))

GetProcAddress(PSAPI,"EnumProcesses");

GetModuleFileNameExA=(DWORD(WINAPI *)(HANDLE hProcess,HMODULE hModule,LPTSTR lpstrFileName,DWORD nSize))

GetProcAddress(PSAPI,"GetModuleFileNameExA");

if(NULL == EnumProcesses||NULL == GetModuleFileName)

return FALSE;

else

return TRUE;

}

__fastcall TForm1::TForm1(TComponent* Owner)

: TForm(Owner)

{

}

//---------------------------------------------------------------------------

void __fastcall TForm1::FindAllProcessFileNameClick(TObject *Sender)

{

OSVERSIONINFO osinfo;

osinfo.dwOSVersionInfoSize=sizeof(OSVERSIONINFO);

//取当前操作系统类型

if(GetVersionEx(&osinfo))

{

switch(osinfo.dwPlatformId)

{

//当前操作系统是WIN9X

case VER_PLATFORM_WIN32_WINDOWS:

if(InitToolHelp32())

{

ListBox1-Clear();

p32.dwSize=sizeof(PROCESSENTRY32);

//初始化TOOLHELP32快照

HANDLE pName=CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS,NULL);

//开始查找

BOOL Next=Process32First(pName,&p32);

i=0;

//遍历进程

while(Next)

{

//显示进程

ListBox1-Items-Add(p32.szExeFile);

//根据进程ID获取句并

process[i]=OpenProcess(PROCESS_TERMINATE,0,p32.th32ProcessID);

//继续查找

Next=Process32Next(pName,&p32);

i++;

}

CloseHandle(pName);

}

break;

//当前操作系统是NT

case VER_PLATFORM_WIN32_NT:

if(InitPSAPI())

{

ListBox1-Clear();

//获取当前进程个数

EnumProcesses(process_ids,sizeof(process_ids),&num_processes);

//遍历进程

for(i=0; i

{

//根据进程ID获取句并

process[i]=OpenProcess(PROCESS_QUERY_INFORMATION|PROCESS_VM_READ

,0,process_ids[i]);

//通过句并获取进程文件名

if(GetModuleFileNameExA(process[i],NULL,file_name,sizeof(file_name)))

ListBox1-Items-Add(file_name);

}

}

break;

}

}

}

//---------------------------------------------------------------------------

void __fastcall TForm1::ListBox1Click(TObject *Sender)

{

int iCount;

iCount=ListBox1-ItemIndex;

ListBox1-Hint=ListBox1-Items-Strings[iCount];

}

//---------------------------------------------------------------------------

else ShowMessage("初始化TOOLHELP32失败");

}

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
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- 王朝網路 版權所有