亚洲成精品动漫久久精久,九九在线精品视频播放,黄色成人免费观看,三级成人影院,久碰久,四虎成人欧美精品在永久在线

掃一掃
關注微信公眾號

WIN 9X下查找隱藏進程實現方法
2007-06-05   中國IT實驗室

在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失敗");
  }

熱詞搜索:

上一篇:Win2k下進程不死術
下一篇:Win2000系統進程列表

分享到:   收藏