青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Xiao.Zhu C++

Xiao.Zhu C++

  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
  29 隨筆 :: 14 文章 :: 17 評論 :: 0 Trackbacks

上一次我們說了目標程序的啟動,以及對目標程序的預處理。這一節中爭取可以將外掛的窗口顯出來,具體能不能說這么多,只能看著辦了。

因為我決定采用最俗的辦法Hook來注入線程(有時候我都覺得自己是否有必要這么做,因為Debug的辦法也不錯),為了程序的更普遍性和更快的移植,以及簡單一點,我決定還是采用Hook。這里提前說一下,如果不懂匯編和程序調試的話,最好先補一下課,這在以后要用的。

  我們先來編寫Hook.dll部分,程序的啟動部分暫時不用理會了(我以后就將那部分叫做wg.exe吧),昨天著急忘了說一聲了,我讓屏蔽的WriteProcessMemory中的數據地址是大話9.16更新之前的最后一個版本,在9.16更新之后的版本中需要先將程序脫殼,這部分我在以后會說的,所以讓大家屏蔽掉那兩個寫內存的操作。
對于Hook.dll來說,我們準備使用F12鍵來激活外掛,在CB中編寫dll非常簡單,建立一個dll項目工程,然后就可以添加代碼了。建立工程的時候一點記得選上使用C++,使用VCL,Multi Thread這幾個選項,理由:

  1、使用C++是為了讓我省點口水(我將APIHOOK封裝到了一個類里面)。

  2、使用VCL是因為我太懶惰,不想編寫界面代碼。

  3、使用多線程是因為程序必須。

  由于外掛主窗體在dll中,因此生成的dll就會比一般的dll大。窗體其實可以放到任何地方的,只是放到dll中比較方便而以,而且在說的時候可以更好的分開。

  以下是Hook.cpp的代碼:

//---------------------------------------------------------------------------
#include <vcl.h>
#include <windows.h>
#include "hookapi.h"
#include "hookform.h"
#pragma hdrstop

#pragma argsused
HHOOK g_hHook = NULL;//Hook的句柄
HINSTANCE DllHinst = NULL; //Dll的句柄
HWND gamehWnd; //游戲句柄
HANDLE hThread = NULL; //線程句柄
HWND wghandle = NULL; //外掛窗口句柄
HANDLE gamehandle; //游戲窗口句柄,忘了有沒有用
HINSTANCE gameInstance; //游戲的,也不知道用了沒用
DWORD ThreadID; //線程ID

LRESULT CALLBACK KeyBoardHook(int nCode, WPARAM wParam, LPARAM lParam);//鍵盤Hook
extern "C" __declspec(dllexport)bool EnableHook(DWORD dwThreadId);//啟動Hook的函數
extern "C" __declspec(dllexport)bool DisableHook();//卸載Hook的函數,和上面的函數一樣都是為了外部可以控制

DWORD WINAPI Thread1(PVOID param);//線程函數,在該函數中,將啟動外掛窗口

int WINAPI DllEntryPoint(HINSTANCE hinst, unsigned long reason, void* lpReserved)
{
 DllHinst = hinst;//載入Dll
 return 1;
}
extern "C" __declspec(dllexport)bool EnableHook(DWORD dwThreadId)
// 導出函數EnableHook()
{
 if (g_hHook == NULL)
 // 安裝新鉤子
 {
  g_hHook = SetWindowsHookEx(WH_KEYBOARD, (HOOKPROC)KeyBoardHook, DllHinst,
dwThreadId);
  /*記得CreateProcess中的參數嗎?我們傳進的參數是目標程序的主線程ID,表示我們啟動的是線程Hook,而不是全局Hook,這樣不會對其他程序產生任何影響*/
 }
 if (g_hHook)
 {
  return true;
 }
 return false;
}
extern "C" __declspec(dllexport)bool DisableHook() // 導出函數DisableHook()
{
 /*卸載Hook,現在暫時先這樣了,其實在真實的情況下如果要做的完美的話,需要做許多事情,如果直接關閉客戶端的話,這樣就足夠了,這個函數其實并沒有任何的用處,這里僅僅是為了說明外部可以主動控制外掛的啟動和關閉而已*/
 if (g_hHook != NULL)
 {
  UnhookWindowsHookEx(g_hHook);
  g_hHook = NULL; // 卸掉新鉤子
  return true;
 }
 return false;
}
LRESULT CALLBACK KeyBoardHook(int nCode, WPARAM wParam, LPARAM lParam)
{
 if (nCode >= 0)
 {
  if (wParam == 123)
   //123為F12的鍵碼,可以查看MSDN或者Windows API參考方面的書找到,自己寫個小程序測試也可以
  {
   if (hThread == NULL)
   //這里確保線程啟動一次,而不是多次,每一次的啟動都回引入一個外掛窗口
   {
    hThread = CreateThread(NULL, 0, Thread1, NULL, NULL, &ThreadID);
    //啟動線程,該線程很快執行完畢
   }
  }
 }
 return (CallNextHookEx(g_hHook, nCode, wParam, lParam));//剩下的讓目標程序去處理
}

  Dll中的函數是外掛程序的核心。在線程啟動成功之后,就可以卸載Hook了,這里只是為了簡便,所以將Hook仍然保留。

在CB中編程的時候,最好將程序的文件名保存成你想要的名字,別用默認的名字,默認的名字是Unit+數字組成,而不是類名之類的,這是我不喜歡CB的一個原因,另外一個原因是沒有全屏幕專家界面,編寫代碼的時候其他的太礙事,第三個原因是可以在任意的地方寫代碼,
我的代碼又沒有具體的風格,經常造成莫名其妙的錯誤。喜歡他的原因是因為用它開發東西太快了,而且方便,比在VC中默寫代碼方便多了。

  廢話說完,可以添加外掛窗口的視圖,在New菜單中選擇New Form,如果你想New其他的話我不反對,能不能得到正確的結果我就不知道了。

  網上有不少人問怎么在游戲中彈出外掛窗口,我已經回答的有點不耐煩了。在CB中做是最方便的事情了,但得設置好控件的屬性,因為我對使用VC來編寫界面不熟悉,更多的時候我都是直接使用API來編寫的(我沒有學習MFC的打算),所以對于喜歡VC的朋友們只能說抱歉了。

對于新窗體的屬性設置是最重要的,要不然莫名其妙的錯誤和結果讓人變得神經。下面是我對dll中窗體屬性的一些總結,如果你有其他不懂的地方,可以給我E-Mail或者MSN或者QQ。

  1、 Visible屬性一定要為false,否則窗體沒辦法移動

  2、 FormStyle屬性最好為fsNormal,但一定不要是fsMDIChild或者fsMDIForm,這兩個會引起莫名其妙的錯誤。

  3、 如果剛開始彈不出來的話,將BorderStyle屬性改為bsDialog。我在后面的教程中由于要重載TForm的函數,因此這里是不是必須為bsDialog不太清楚了,畢竟是很早以前的代碼了。

  其他的注意點好像沒有了。下面是CreateThread調用中的Thread1函數實現:

DWORD WINAPI Thread1(PVOID param)
{
 TwgHookForm* wgHookForm;
 wgHookForm = new TwgHookForm(NULL);
 wghandle = wgHookForm->Handle;
 /*暫時將下面的發送消息屏蔽掉,我在窗體創建之后需要窗體做一部分必要動作,所以采用發送消息的機制來了,其實并不是必需這么做的,由許剛開始編寫的時候,APIHOOK中的內容都是通過Message的方式來做的,這里為了方便就通過Message來弄了,算是點歷史原因吧*/
 SendMessage(wghandle, WM_USER + 2, NULL, NULL);
 wgHookForm->ShowModal();
 delete wgHookForm;
 return 1;
}

  到現在為止應該可以在游戲中彈出外掛窗口了,我們的第一步也算完成了,外掛程序的平臺到現在為止搭建完了,剩下的就是工具的制作和必要代碼的編寫。

posted on 2007-04-28 15:55 Xiao.Zhu 閱讀(798) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美在线黄色| 国产精品久久久免费| 亚洲欧洲精品成人久久奇米网| 99国产精品久久| 亚洲激情视频| 夜夜精品视频一区二区| 99精品欧美一区二区蜜桃免费| 国产精品美女一区二区在线观看| 欧美色欧美亚洲高清在线视频| 欧美日韩裸体免费视频| 国产精品a久久久久久| 国产精品久久久久99| 国产三级欧美三级| 亚洲丶国产丶欧美一区二区三区 | 午夜亚洲性色视频| 欧美一区二区在线免费观看| 久久精品视频免费| 亚洲国产精品嫩草影院| 99精品视频免费观看| 欧美一级二级三级蜜桃| 免费黄网站欧美| 国产精品免费一区豆花| 怡红院av一区二区三区| 在线综合亚洲欧美在线视频| 亚洲已满18点击进入久久| 午夜激情综合网| 免费欧美电影| 亚洲午夜一二三区视频| 久久久亚洲综合| 欧美午夜免费影院| 在线观看一区| 亚洲欧美日韩在线观看a三区| 欧美高清在线观看| 亚洲欧美日本在线| 欧美成人精品高清在线播放| 国产日韩欧美精品综合| 亚洲国产专区| 国产一区二区中文| 亚洲午夜在线观看视频在线| 午夜精品久久久久久99热软件| 久久精品亚洲精品国产欧美kt∨| 欧美大片在线观看一区二区| 一区二区三区精品视频在线观看| 性做久久久久久久久| 牛人盗摄一区二区三区视频| 欧美午夜视频| 伊人激情综合| 1000部国产精品成人观看| 久久久久www| 欧美国产一区在线| 国产一区二区三区av电影| 一本色道久久88亚洲综合88| 久久精品国产亚洲精品| 亚洲精品专区| 久久久亚洲高清| 国产美女扒开尿口久久久| 亚洲国产精品国自产拍av秋霞 | 在线成人av| 亚洲欧美韩国| 亚洲全部视频| 久久精品中文字幕一区| 欧美日韩国产在线播放| 亚洲国产成人在线播放| 久久国产一区二区三区| 亚洲香蕉在线观看| 欧美经典一区二区| 91久久精品国产91性色| 老**午夜毛片一区二区三区| 日韩视频在线免费| 免费在线欧美视频| 欧美日韩激情小视频| 欧美日韩在线播放一区| 在线观看日韩一区| 久久免费黄色| 久久大香伊蕉在人线观看热2| 国产精品美女xx| 亚洲一区二区在线看| 亚洲人永久免费| 美国三级日本三级久久99| 国产一区观看| 亚洲欧美日韩天堂一区二区| 久久精品国产96久久久香蕉| 一区二区av在线| 欧美激情第三页| 亚洲一区二区三区四区视频| 最新成人av在线| 久久久久欧美精品| 亚洲精品少妇30p| 亚洲国产精品成人精品| 欧美视频一二三区| 欧美一级二级三级蜜桃| 久久午夜精品| 亚洲免费成人av电影| 亚洲一二区在线| 国产日韩精品久久| 欧美激情第二页| 欧美激情亚洲激情| 亚洲综合电影一区二区三区| 亚洲精品在线二区| 国产精品美女在线| 久久精品视频va| 久久综合色天天久久综合图片| 欧美无乱码久久久免费午夜一区| 一本一本大道香蕉久在线精品| 一本综合久久| 国产精品一区二区三区四区| 久久久av水蜜桃| 欧美xx视频| 亚洲欧美国产精品桃花| 久久久91精品国产一区二区三区| 亚洲国产婷婷香蕉久久久久久99 | 亚洲性视频网址| 先锋影音网一区二区| 亚洲第一视频网站| 一本久道久久综合婷婷鲸鱼| 欧美午夜视频网站| 久久人人爽人人爽| 欧美精品免费播放| 久久精品国产第一区二区三区最新章节 | 亚洲人成艺术| 中国成人在线视频| 又紧又大又爽精品一区二区| 亚洲毛片视频| 亚洲国产高清自拍| 亚洲综合999| 欧美日韩直播| 欧美高清视频一区二区| 国产欧美va欧美va香蕉在| 欧美激情精品久久久久久免费印度 | 欧美国产精品v| 亚洲网站在线| 久久在线观看视频| 午夜精品久久久久久| 亚洲成人自拍视频| 亚洲高清资源| 99精品国产在热久久婷婷| 国内精品免费在线观看| 亚洲男人影院| 99天天综合性| 欧美视频网站| 亚洲精品中文在线| 亚洲一区二区三区久久| 欧美裸体一区二区三区| 亚洲精品日韩久久| 亚洲黄色精品| 欧美日韩ab片| 亚洲国产视频直播| 一级成人国产| 欧美成人一区二区| 亚洲理论在线| 一区二区三区.www| 欧美欧美午夜aⅴ在线观看| 欧美激情一区二区三区不卡| 在线不卡中文字幕| 久久免费视频这里只有精品| 久久久久国产精品麻豆ai换脸| 欧美性大战久久久久| 美脚丝袜一区二区三区在线观看| 欧美日韩一区二区在线视频| 最新中文字幕亚洲| 制服丝袜激情欧洲亚洲| 欧美日韩国产专区| 夜夜嗨av一区二区三区四季av| 一区二区高清视频| 欧美日韩一区二区三区在线| 一区二区三区黄色| 一区二区三区www| 欧美日韩另类视频| 一本久道久久综合中文字幕| 亚洲综合另类| 国产欧美日韩视频在线观看| 亚洲欧美视频一区二区三区| 欧美一区二区视频在线观看2020| 欧美性猛交xxxx免费看久久久| 一本到高清视频免费精品| 精品99一区二区| 欧美影院在线播放| 欧美激情a∨在线视频播放| 亚洲精品久久视频| 国产精品久久久久久亚洲调教 | 亚洲影院在线| 欧美精品v日韩精品v国产精品| 亚洲精品123区| 午夜精品99久久免费| 激情丁香综合| 欧美一区二区播放| 亚洲成人在线视频播放 | 亚洲国产视频一区二区| 亚洲影院在线| 伊人婷婷欧美激情| 欧美视频中文字幕在线| 久久av免费一区| 日韩午夜精品视频| 亚洲免费在线观看| 在线日韩欧美| 国产精品自拍网站| 亚洲国产二区| 可以免费看不卡的av网站| 99av国产精品欲麻豆| 国产老肥熟一区二区三区|