日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > windows >内容正文

windows

【超详细】遍历Windows进程模块

發(fā)布時間:2025/3/19 windows 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【超详细】遍历Windows进程模块 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

直奔主題

摘要
上一篇文章詳細介紹了如何 遍歷Windows進程。這篇文章主要是對獲取的系統(tǒng)進程作進一步處理,依次遍歷每一個進程中使用的模塊!主要是用到了Module32First以及Module32Next兩個函數(shù),思路就是在之前的進程外層循環(huán)中新增一個模塊內(nèi)層循環(huán)

具體思路
(1).使用CreateToolhelp32Snapshot以及傳參TH32CS_SNAPPROCESS創(chuàng)建系統(tǒng)進程快照
(2).使用Process32First獲取第一個進程的信息存入到PROCESSENTRY32結(jié)構(gòu)體中
(3).再用CreateToolhelp32Snapshot以及傳參TH32CS_SNAPMODULE創(chuàng)建系統(tǒng)進程的模塊快照
(4).使用Module32First獲取第一個模塊信息存到MODULEENTRY32結(jié)構(gòu)體中
(5).然后使用Module32Next循環(huán)當前進程的所有模塊
(6).再用Process32Next遍歷所有進程
(7).最后用CloseHandle關(guān)閉所有句柄

完整代碼

#include <stdio.h> #include <stdlib.h> #include <windows.h> #include <Tlhelp32.h>BOOL SetProcessPrivilege(char *lpName, BOOL opt);int main(int argc, char *argv[]) {PROCESSENTRY32 pe32;MODULEENTRY32 me32;HANDLE hProcess, hSnapshot_proc, hSnapshot_mod;pe32.dwSize = sizeof(pe32);SetProcessPrivilege("SeDebugPrivilege", 1);hSnapshot_proc = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);if (Process32First(hSnapshot_proc, &pe32)){do{hProcess = OpenProcess(PROCESS_QUERY_INFORMATION | PROCESS_VM_READ, FALSE, pe32.th32ProcessID);if (pe32.th32ProcessID && pe32.th32ProcessID != 4 && pe32.th32ProcessID != 8){printf("PID: %d >>> ProcName: %s\n", pe32.th32ProcessID, pe32.szExeFile);me32.dwSize = sizeof(me32);hSnapshot_mod = CreateToolhelp32Snapshot(TH32CS_SNAPMODULE, pe32.th32ProcessID);Module32First(hSnapshot_mod, &me32);do{printf("ModName: %s -> Path: %s\n", me32.szModule, me32.szExePath);} while (Module32Next(hSnapshot_mod, &me32));printf("------\n\n");CloseHandle(hSnapshot_mod);}CloseHandle(hProcess);} while (Process32Next(hSnapshot_proc, &pe32));}SetProcessPrivilege("SeDebugPrivilege", 0);CloseHandle(hSnapshot_proc);system("pause");return 0; }BOOL SetProcessPrivilege(char *lpName, BOOL opt) {HANDLE tokenhandle;TOKEN_PRIVILEGES NewState;if (OpenProcessToken(GetCurrentProcess(), TOKEN_ADJUST_PRIVILEGES | TOKEN_QUERY, &tokenhandle)){LookupPrivilegeValue(NULL, lpName, &NewState.Privileges[0].Luid);NewState.PrivilegeCount = 1;NewState.Privileges[0].Attributes = opt != 0 ? 2 : 0;AdjustTokenPrivileges(tokenhandle, FALSE, &NewState, sizeof(NewState), NULL, NULL);CloseHandle(tokenhandle);return 1;}else{return 0;} }

編譯命令gcc mod1.c -o mod1,注意程序的OpenProcess并不是必要的,只是為了加深進程提權(quán)的理解

運行截圖
由于內(nèi)容太多控制臺顯示不全,設置緩沖區(qū)的高度即可完全顯示

END

總結(jié)

以上是生活随笔為你收集整理的【超详细】遍历Windows进程模块的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。