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

道。道。道

安全特性不等于安全的特性

   :: 首頁 :: 聯系 :: 聚合  :: 管理

常用鏈接

搜索

  •  

最新評論

  現在大部分的主流外掛,包括按鍵精靈,自動做一些動作之類的外掛。 都是通過HOOK進游戲窗口,并且用不同的HOOK類型來完成的,比如對于 網絡,通常是通過HOOK消息,把DLL弄到我們的游戲程序中,然后通過
GetProcAddress得到DLL中它們卑劣的函數的地址和真實的函數地址, 然后通過WriteProcessMemory來把我們的函數地址改成他們他們的API 地址。

  那么在我們的游戲執行的時候,收到消息就會先觸發他們的鉤子,等他們布置好邪惡的陷阱,然后再執行我們的程序。那么,對于這類型的外掛,該怎么防呢?俗話說得好,以彼之道,還制彼身。所謂魔高一尺,道高一丈。所謂邪不勝正。所謂天網恢恢。所謂做賊心虛。

  恩,WINDOWS的鉤子有個特點,就是鉤子鏈,因為對于同一個進程,即使是同一類型的鉤子,能同時有多個,也就是說,對于同一個游戲,開兩個功能相同的外掛也可以。那么,怎么樣來決定鉤子的順序呢?所謂
后來者先得,WINDOWS的做法是,最后一個HOOK某個進程的鉤子最先執行。并且振奮人心的消息是,在鉤子里面可以控制下一個鉤子是否執行。

  這個函數是CallNextHookEx,也就是說,如果在某個鉤子里面不執行這個函數的話,鉤子鏈就會在這中斷,那么我們的思路就很簡單了,在游戲運行中,開一個進程,每隔一段時間就hook我們的主程序,然后在鉤
子里面,不執行CallNextHookEx,這樣就可以避免別人的鉤子執行。

  所謂,僅僅發現敵人還不夠,還要消滅敵人。不急,我們來看看如何徹底把敵人打成粉碎性骨折。恩,要消滅敵人就要復雜一點了,要針對不同類型的鉤子來采取不同類型的方法了,因為敵人的鉤子不管怎么做,
無非是出于兩種目的,一種是修改數據,另外就是過濾數據。其核心思想就是我們自己的游戲注冊兩個鉤子,一個總是在鉤子鏈的最底層,另外一個總是在鉤子鏈的最上層,一比較兩個鉤子收到的消息,就知道中
間有沒有別的鉤子了。一但發現有別的鉤子,不用想了,肯定是外掛,最少也用了按鍵精靈,封號,殺檔,想怎么干就怎么干。

  當然,敵人也不是這么脆弱的,據說有人用raw socket來截獲所有的網絡消息,這個跟鉤子無關,這個更底層一些。不過不用怕,俗話說得好,以彼之道,還制彼身。所謂魔高一尺,道高一丈。所謂邪不勝正。所謂
天網恢恢。所謂做賊心虛。對付攔截raw socket的外掛,這里首先要把敵人分類,對于水平最次的敵人,方法也相應要簡單得多。 最次的敵人一般用的方法是自己寫一個wsock32.dll放在和游戲相同的目錄下,來替換掉系統的wsock32.dll。對于這種愚蠢的方法,解決的辦法有很多,把load time的載入wsock32.dll改成run time的載入,然后指定一下路徑,就什么問題都沒有了。更簡單點,運行游戲的時候檢查一下當前目錄下有沒有wsock32.dll,有的話,那就肯定是外掛鉤子了。

  比最等級高一點點的敵人,會喜歡用鉤子來直接鉤,一般的做法是,先通過GetProcAddress來獲取SOCKET API的地址,然后通過WriteProcessMemory的方法來修改入口地址,將其改成jmp 自己的函數地址。這種方法其實很卑劣的,所謂無毒不丈夫,我們可以通過修改通用的GetProcAddress的代碼來防止別人攔截SOCKET,這樣,直接連防火墻都可以突破了。

  這里的技術難點在于,我們不能用類似WriteProcessMemory的方法來寫內存因為我們不知道究竟外掛是哪個進程,所以我們需要修改WINDOWS的代碼段,這樣講理論上是不可能的,可惜WINDOWS自己給自己留了個后門,在kernel.dll 里面,UINT AllocCsToDsAlias(UINT),通過把API的代碼段的選擇符傳給它,可以返回一個可以寫的數據段的選擇符,然后把新的選擇符和API的入口地址加在一起,就可以得到一個可以寫的代碼段的指針。

  國內好多取詞軟件和全屏翻譯軟件都是用的這個原理,具體的例子如下:
  比如GetProcAddress這個API,在kernel.dll里面,我們要做針對它的通用鉤子就應該按照以下的步簇:
typedef UINT (WINAPI* FOO)(UINT);
FOO AllocCsToDsAlias;
HMODULE hKernel = GetModuleHandle("kernel");
AllocCsToDsAlias = (FOO)GetProcAddress(hKernel, "AllocCsToDsAlias");
FARPROC entry = GetProcAddress(hKernel, "GetProcAddress");
WORD offset = (WORD)(FP_OFF(entry));
UINT selector = AllocCsToDsAlias(FP_SEG(entry));
BYTE *addr = (BYTE *)MK_FP(selector, offset);

  然后就可以往addr這個地址寫5個BYTE的東西,第一個BYTE是jmp,不同的CPU 可能會不同,之后的一個DWORD是你的函數的地址。。

  這樣,可以通過保存兩份addr的數據來做到鉤子的開關,當鉤子打開的時候,所有的GetProcAddress的調用都會調到我們的函數,這個時候可以通過檢查如果有人想GetProcAddress wsock32.dll里的東西,我們就干掉它。。

  同樣,如果有人通過開啟socket這個API的SOCK_RAW參數來調用RAW SOCKET監視網絡,我們也可以通過上面的方法來做到先入為主,看誰在監視我們的網絡傳輸。

  其實查外掛的原理和捉病毒的原理一樣,只是現在做外掛的技術還不成熟。當做外掛的技術和防外掛的技術在同一條線上的時候,想從技術上防住外掛是不可能的。

  其實是無奈,殺毒軟件的做法是出來一種新的病毒,在第一時間內公布其特征碼,然后更新所有的客戶端,看到這種特征的,就殺。其實查殺外掛也該如此,其實CS的Cheating-Death就是這個原理,不管出了什么新的外掛,CD 總是在第一時間內更新,然后客戶端也就傻傻的只要一看到有這個特征的東西就把它干掉。其實仔細想想,這是個很好的主意,從外掛開發商的動機來分析。他們之所以要開發外掛,估計炫耀技術是一方面,更重要的還是想賺錢,或者用來掛機之類的,既然要賺錢,或者掛機,就必然會被其他玩家發現或者舉報,這個時候應該做的就是盡快的下載一份外掛,或者根據其行為研究其特征,并在防外掛的特征碼上記下一筆,其實不用太復雜,最簡單的做法就是記住其外掛窗口的名稱,然后只要看到這個外掛窗口,做些處理就好了。

  那么這樣一來,關鍵的技術就落在如何設計查外掛這個結構上了,首先客戶端需要的是一個查外掛引擎,和一個外掛特征庫,根據引擎和特征庫生成一個固定的版本號,然后每次登陸的時候就用這個版本號,跟服務器上的版本號對比,如果不一樣的話,則從服務器自動下載最新的查外掛引擎和外掛特征庫。

  這樣雖然不能將外掛趕盡殺絕,卻能比較大的限度上圍剿使用外掛的風氣,相信使用外掛的玩家也只是想更好的玩游戲,只不過動的念頭有些歪了,但其出發點仍是好的,只要在他使用外掛的時候多些阻攔或者誘導他不使用外掛,這樣效果就會好很多。設想一下,誰愿意每天等一個外掛的更新,而不去玩他很想玩的游戲呢。這樣一來,制作外掛的人也會逐漸減少,從而進入一個良性循環。

  就好象如今寫病毒,并不如當年那么流行了。。-。-

posted on 2006-11-18 16:49 獨孤九劍 閱讀(365) 評論(0)  編輯 收藏 引用 所屬分類: misc
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲毛片在线观看| 在线精品观看| 国产精品白丝av嫩草影院| 欧美视频精品在线| 国产精品视频区| 很黄很黄激情成人| 日韩特黄影片| 久久国产手机看片| 欧美成人首页| 亚洲视频香蕉人妖| 欧美va亚洲va香蕉在线| 久久综合999| 国产精品成av人在线视午夜片| 在线中文字幕日韩| 快she精品国产999| 一本色道久久综合| 麻豆精品一区二区综合av| 国产精品三上| 欧美福利视频一区| 欧美性做爰猛烈叫床潮| 欧美在线亚洲综合一区| 最新中文字幕亚洲| 亚洲永久在线| 亚洲成人中文| 亚洲欧美亚洲| 欧美视频精品在线| 久久综合色综合88| 欧美日韩亚洲在线| 亚洲理论在线| 欧美777四色影视在线| 欧美一区二区三区在| 国产精品手机视频| 欧美激情亚洲自拍| 欧美国产日产韩国视频| 亚洲国产高清一区| 久久久久久久一区二区| 亚洲一区二区视频在线观看| 欧美日韩直播| 免费在线成人av| 久久综合伊人77777蜜臀| 亚洲综合社区| 欧美成人69| 久久亚洲影院| 免费看精品久久片| 久久精品天堂| 国产精品国产三级国产专播精品人| 一本久道久久久| 9色国产精品| 国产精品成人一区二区网站软件 | 欧美在线观看网站| 亚洲一级黄色| 国产在线麻豆精品观看| 久久青青草综合| 久久久久**毛片大全| 亚洲成色精品| 欧美在线|欧美| 在线观看亚洲一区| 亚洲欧美日韩人成在线播放| 一区二区三区视频在线观看| 嫩模写真一区二区三区三州| 久久精品男女| 国产精品一区免费观看| 久久亚洲高清| 国产原创一区二区| 新狼窝色av性久久久久久| 亚洲国产精品福利| 久久性天堂网| 欧美一级成年大片在线观看| 性欧美超级视频| 久久本道综合色狠狠五月| 国产精品亚洲产品| 欧美一区二区三区免费观看视频| 亚洲欧美日韩国产中文| 久久婷婷激情| 欧美成人中文字幕在线| 日韩视频二区| 欧美日韩亚洲在线| 亚洲一区观看| 久久综合九色综合网站| 在线成人av网站| 亚洲一区二区3| 欧美在线综合| 亚洲国产91| 欧美精品尤物在线| 久久久99久久精品女同性| 国产亚洲精品成人av久久ww| 亚洲激情校园春色| 亚洲一区二区精品视频| 欧美成人自拍| 亚洲视频播放| 老鸭窝亚洲一区二区三区| 亚洲精品少妇| 久久九九久久九九| 亚洲国产导航| 在线免费观看视频一区| 欧美精品aa| 亚洲第一页自拍| 亚洲一区二区三区中文字幕| 国产日韩欧美在线观看| 在线视频欧美日韩| 久久久亚洲国产天美传媒修理工 | 国产精品久久久久久久9999| 性欧美大战久久久久久久免费观看| 久久久久久网站| 9久草视频在线视频精品| 国产视频一区二区在线观看 | 亚洲欧美一级二级三级| 欧美成人一区二区三区在线观看| 99这里只有久久精品视频| 国产亚洲激情在线| 欧美日韩国产亚洲一区| 亚洲日本中文字幕| 亚洲精品一区二区三区樱花 | 欧美成人黄色小视频| 亚洲网站啪啪| 亚洲高清视频在线| 久久精品国产精品亚洲精品| 亚洲三级影片| 黑人一区二区| 国产精品毛片一区二区三区| 99精品国产一区二区青青牛奶| 久久久五月婷婷| 亚洲影院高清在线| 日韩一级精品视频在线观看| 国产综合色产| 国产日韩欧美视频| 国产精品热久久久久夜色精品三区 | 亚洲欧美在线磁力| 国产精品视频你懂的| 欧美精品九九99久久| 久久亚洲国产精品日日av夜夜| 亚洲免费网站| 免费日韩av电影| 久久国产精彩视频| 性欧美暴力猛交69hd| 亚洲香蕉视频| 一区二区三区成人精品| 日韩午夜在线| 亚洲精品国产无天堂网2021| 伊人久久大香线蕉综合热线| 国产亚洲免费的视频看| 国产女人水真多18毛片18精品视频| 欧美伊人久久久久久午夜久久久久 | 99热这里只有成人精品国产| 亚洲精品极品| 日韩视频中文字幕| 99人久久精品视频最新地址| 日韩视频第一页| 正在播放欧美一区| 欧美午夜精品一区| 欧美日精品一区视频| 欧美日韩另类视频| 欧美偷拍另类| 国产精品美女主播| 国产伦精品一区二区三区四区免费| 国产精品成人一区二区网站软件 | 欧美—级高清免费播放| 欧美国产先锋| 欧美天天影院| 国产欧美一区二区视频| 国产视频亚洲精品| 在线观看不卡| 亚洲美女毛片| 欧美亚洲视频在线看网址| 午夜国产精品影院在线观看| 久久国产精品高清| 欧美成年人网| 亚洲精品在线免费观看视频| 亚洲午夜羞羞片| 久久久久免费观看| 中文无字幕一区二区三区| 亚洲一区二区3| 久久精品中文字幕一区| 欧美国产日韩一二三区| 国产精品久久久久91| 国产一区二区三区在线观看精品 | 国内一区二区三区| 亚洲国产日韩欧美| 激情六月婷婷综合| 国产精品一香蕉国产线看观看 | 欧美第一黄色网| 国产精品视频免费观看| 亚洲福利视频免费观看| 一本高清dvd不卡在线观看| 欧美一区午夜精品| 亚洲国产第一| 欧美中文字幕在线视频| 欧美日韩成人在线| 精品成人一区二区三区| 亚洲午夜久久久| 欧美国产日韩二区| 欧美在线中文字幕| 国产精品xvideos88| 91久久精品一区二区三区| 狠狠v欧美v日韩v亚洲ⅴ| 一区二区三区视频在线看| 毛片一区二区| 亚洲综合激情| 欧美日韩精品在线| 亚洲国产免费|