Win32ASM-進程學習【2】

獲取運行中的句柄

?

1.從窗口句柄中獲取進程句柄

要對進程進行某種操作,就必須首先知道該進程的句柄或者進程ID

對于自己創建的子進程來說CreateProcess函數返回了子進程句柄和進程的ID

但是如果如果要對系統中運行的某個進程進行操作,那么首先獲取他們的句柄才行

?

如果知道某個進程的ID

那么可以通過GetWindowThreadProcessID hWnd,lpdwProcessID

該函數可以從一個窗口句柄中獲取創建該窗口的進程的進程ID

hWnd指明一個窗口句柄--可以通過FIndWindow來獲得這個窗口句柄

lpdwProcessID指向一個雙字節的變量,函數在這里返回創建窗口進程的ID

函數的返回值是目標進程中創建該窗口的線程的線程ID

?

得到進程ID后,就可以通過OpenProcess函數來獲取該進程的句柄了

OpenProcess dwDesiredAccess,bInheritHandle,dwProcessID

dwDesireAccess 指定需要對該進程進行的操作,要對目標進程進行某種操作

一般來說,除了系統進程以外,可以對其他函數進行任何操作,操作碼可以取以下取值的組合

PROCESS_ALL_ACCESS? 等于下面全部操作的組合

PROCESS_CREATE_THREAD 允許創建遠程線程

PROCESS_DUP_HANDLE 允許進程句柄被復制

PROCESS_QUERY_INFORMATION 允許使用GetExitCodeProcess查詢進程退出碼和使用GetPriorityClass函數查詢進程的優先級

PROCESS_SET_INFORMATION? 允許使用SetPriorityClass函數設置進程優先級

PROCESS_VM_OPERATION 允許使用WriteProcessMemory 和 VirtualProtectEx函數修改進程的地址空間

PROCESS_VM_READ 允許對進程空間進行讀操作

PROCESS_WRITE 允許對進程地址空間進行寫操作

?

bInheritHandle 指明返回的進程句柄是否可以被當前進程的子進程繼承,如果參數指定為TRUE,則進程句柄可以被繼承

dwProcessID指明目標進程的ID

如果函數成功執行,返回的是被打開的進程句柄,如果函數執行失敗則返回NULL.一般打開失敗的原因是由于權限不夠引起的,當完成對目標進程的操作之后,必須使用CloseHandle將獲得的句柄關閉

?

2.從快照函數獲取進程句柄

(1)

使用GetWindowThreadProcessID獲取進程的先決條件是必須創建了窗口,對于在后臺運行的沒有窗口的進程該如何處理呢?

這就可以通過枚舉系統中運行的進程來解決了,這個功能可以由CreateToolHelp32Snapshot函數來實現

CreateToolHelp32Snapshot dwFlags,th32ProcessID

dwFlags 用來指定快照中需要返回的對象,本函數不僅可以獲取進程列表,也可以用來獲取線程和模塊等對象的列表,參數可以指定的值是:

TH32CS_SNAPHEAPLIST 對指定進程中的堆進行枚舉

TH32CS_SNAPMODULE 對指定進程中的模塊進行枚舉

TH32CS_SNAPPROCESS 對系統范圍中的進程進行枚舉

TH32CS_SNAPTHREAD 對系統范圍中的線程進行枚舉

th32ProcessID參數用來指定一個進程ID? 對于TH32CS_SNAPPROCESS 和TH32CS_SNAPTHREAD這個參數可以為0

因為后2者是對系統范圍內的枚舉

?

如果函數執行成功返回一個快照句柄,否則返回-1

?

(2)從快照句柄中獲取進程參數使用Process32First和Process32Next函數

Process32Next函數循環獲取快照句柄中的進程信息,當不在有剩余信息時,函數返回FALSE

Process32First和Process32Next的第一參數指向一個快照句柄,第2個參數指向一個PROCESSENTRY32結構

Process32Next hSnapshot,lpProcessEntry32

結構定義如下

<span style="font-family:Microsoft YaHei;font-size:13px;">typedef struct tagPROCESSENTRY32 
{  
DWORD dwSize;                           結構的長度
DWORD cntUsage;                         進程的引用計數
DWORD th32ProcessID;                    進程ID
ULONG_PTR th32DefaultHeapID;            進程默認堆的ID
DWORD th32ModuleID;                     進程模塊的ID
DWORD cntThreads;                       被進程創建的線程數
DWORD th32ParentProcessID;              進程的父進程ID
LONG pcPriClassBase;                    被進程創建的線程的基本優先級
DWORD dwFlags;                          內部使用
TCHAR szExeFile[MAX_PATH];              進程對應的可執行文件名稱
} PROCESSENTRY32,  
*PPROCESSENTRY32;</span>

在返回所有進程信息之后,需要使用CloseHandle將快照句柄關閉

在結構體中返回的進程ID(th32ProcessID)和可執行的文件名(szExeFile)是我們最關心的

這樣我們就可以通過OpenProcess來對進程進行各種操作了

?

另外在ListBox能夠為每一項自定義一個32位的自定義數據

LB_SETITEMDATA? 和 LB_GETITEMDATA可以設置和獲取自定義數據

正好可以把th32ProcessID設置進去......

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/375319.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/375319.shtml
英文地址,請注明出處:http://en.pswp.cn/news/375319.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

完美解決IE8有兩個進程的問題

完美解決IE8有兩個進程的問題&#xff0c;照以下方法設置后就只有一個進程了&#xff0c;沒有什么負影響哦&#xff01; 方法&#xff1a; 1、winR&#xff0c;在運行框里輸入&#xff1a;gpedit.msc&#xff0c;回車進入組策略設置。 2、依次展開&#xff1a;計算機配置——管…

【轉】gvim配置及相關插件安裝

0.準備軟件及插件。(a)gvim72.exe 地址ftp://ftp.vim.org/pub/vim/pc/gvim72.exe。(b)vimcdoc-1.7.0-setup.exe 地址http://prdownloads.sourceforge.net/vimcdoc/vimcdoc-1.7.0-setup.exe?download(c)ec57w32.zip 地址http://prdownloads.sourceforge.net/ctags/ec57w32.zip(…

Win32ASM-進程學習[3]-讀寫進程空間

invoke ReadProcessMemory,hProcess,lpBaseAddress,lpBuffer,dwSize,lpNumberOfBytesReadinvoke WriteProcessMemory,hProcess,lpBaseAddress,lpBuffer,dwSize,lpNumberOfBytesWritten hProcess 指定將要被讀寫的目標進程句柄 lpBaseAddress 目標進程中被讀寫的起始線性地址. …

MongoDB使用記錄

安裝服務 使用以下命令將MongoDB安裝成為Windows服務。筆者的MongoDB目錄為D:\Program Files\mongodb mongod --logpath "D:\Program Files\mongodb\data\logs.txt" --logappend --dbpath "D:\Program Files\mongodb\data" --directoryperdb --serviceName…

OC基礎知識

Object C 語言基礎 第一節總括 這一節是對Objective-C(以后簡稱OC)的簡要介紹,目的是使讀者對OC有一個概括的認識。 1.面象的讀者 在閱讀本文之前,應具備使用與C類似的編程語言(如C,C,JAVA)的一些經驗,同時熟悉面向對象編程。 2.OC簡介 OC是以SmallTalk為基礎&#xff0c;建立…

Windows使用篩選器來處理異常

很久木有管博客了 最近也沒有學什么 Dos系統下發生異常后,系統會調用int 24h服務例程,然后根據中斷的返回值決定下一步要做什么,他會在屏幕上顯示ignore Retry Fail Abort 讓用戶選擇進而進行下一步操作 這樣的話 只要應用程序截取int 24h中斷,就可以隨意的"胡作非…

Android 高級編程 RecyclerView 控件的使用

RecyclerView 是Android 新添加的一個用來取代ListView的控件&#xff0c;它的靈活性與可替代性比listview更好。 看一下繼承關系&#xff1a; ava.lang.Object ?android.view.View ?android.view.ViewGroup ?android.support.v7.widget.RecyclerViewKnown Direct …

Android下點亮LED

http://blog.csdn.net/cpj_phone/article/details/43562551轉載于:https://www.cnblogs.com/Ph-one/p/4276974.html

SEH處理異常

Win32為每個線程定義了一個線程信息塊,其中保存了線程的一些屬性數據,線程信息塊的屬性被定義為NT_TIB結構 typedef struct _NT_TIB { struct _EXCEPTION_REGISTRATION_RECORD *ExceptionList; PVOID StackBase; PVOID StackLimit; PVOID SubSystemTib; union { PVOID FiberDa…

Asp.net MVC 4新項目中創建area的后續操作

Asp.net MVC 4新項目中創建area后&#xff0c;往往HomeController與area的HomeController路由發生混淆&#xff0c;需要手工設置一些地方避免mvc無法識別默認路由的狀況。 無廢話具體步驟&#xff1a; 1. 檢查早Global.asax和\App_Start\RouteConfig.cs中是否已經自動添加了Are…

55-混沌操作法之我見:一、逆勢操作.(2015.2.7)

混沌操作法之我見&#xff1a;一、逆勢操作 首先談談&#xff0c;均線以及鱷魚線。單獨的市場價格表達了t時刻價格的個體情況&#xff0c;均線表達了一段時間內價格的綜合情況。t時刻的價格與均線的比較&#xff0c;表達了考慮了過去以及當前綜合價格的比較情況&#xff0c;即t…

SEH鏈和展開操作

每次我們定義了一個新的SEH異常處理回調函數,EXCEPTION_REGISTRATION結構的prev字段都被要求填寫上一個EXCEPTION_REGISTRATION結構的地址,隨著應用程序對模塊的調用一層層深入下去的時候,那么最后回調函數會形成一個SEH鏈 當程序中有多個線程在運行的時候,每個線程中都會存在各…

spring的基本知識

首先是回顧一下spring的基本知識 1、controller 控制器&#xff08;注入服務&#xff09; 2、service 服務&#xff08;注入dao&#xff09; 3、repository dao&#xff08;實現dao訪問&#xff09; 4、component &#xff08;把普通pojo實例化到spring容器中&#xff0c;相當于…

vs2010 EF4.0 訪問mysql

需要安裝mysql-connector-net-6.3.5 6.8.9的安裝完后在dbfirst里找不到對應的提供程序 鏈接字符串里需要 指定下編碼(如果不是gbk的話) <add name"sourceEntities" connectionString"metadatares://*/Model1.csdl|res://*/Model1.ssdl|res://*/Model1.msl;pr…

Win32ASM 變長參數的理解

C語言里面 提供了一些宏 可以使用變長參數 int MsgPrintf(INT dwszBuffer,TCHAR* szCaption,TCHAR* szFormat,...){LPVOID lpszBuffer;va_list pArgList;va_start(pArgList,szFormat);lpszBuffer HeapAlloc(GetProcessHeap(),HEAP_ZERO_MEMORY,100);_vsntprintf((LPTSTR)lpsz…

jquery判斷一個div的邊界是否超出另外一個div的邊界

摘要&#xff1a;本文簡單介紹jquery判斷一個div的邊界是否超出另外一個div的邊界&#xff0c;如果超出邊界做出相應的處理。 1、實現效果 判斷前 判斷后 2、實現思路 實現類似的判斷&#xff0c;主要是獲取兩個div在瀏覽器中的上下左右的四至&#xff0c;在jquery中&#xff0…

Gson解析Json格式數據

//數據定義&#xff1a;class User{ String name; String password; String getName(){}void setName(){}}Gson gsonnew Gson(); ////解析一條json數據&#xff1a;令str為[{"name":"21001","password":"21001"}] User usernew User()…

進程的細節

從今天開始,重新學習一些細節性質的東西 一.在VS開發環境中,應用程序的入口點: _tWinMain WinMainCRTStartup _tWinMain wWinMainCRTStartup _tmain mainCRTStartup _tmain wmainCRTStartup 相關的介…

maven環境快速搭建(轉)

最近&#xff0c;開發中要用到maven&#xff0c;所以對maven進行了簡單的學習。因為有個maven高手在身邊&#xff0c;所以&#xff0c;很快就上手了&#xff0c;我這里算是自我總結吧。關于maven是什么東東&#xff0c;請參考其它文章。 ----------------準備工作-------------…

cocos2d-x3.0 相對布局(一)

2dx相對布局和Android非常類似。假設前完成Android它應該是easy入門。Size widgetSize Director::getInstance()->getWinSize();Text* alert Text::create("Layout", "fonts/Marker Felt.ttf", 30 );alert->setColor(Color3B(159, 168, 176));aler…