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

S.l.e!ep.¢%

像打了激速一樣,以四倍的速度運轉,開心的工作
簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
posts - 1098, comments - 335, trackbacks - 0, articles - 1
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

Inject DLL by IME

Posted on 2010-01-28 22:01 S.l.e!ep.¢% 閱讀(1831) 評論(2)  編輯 收藏 引用 所屬分類: RootKit

Inject DLL是做全局鉤子或者攔截類軟件都有可能用到的技術,如果做G***的話我們也有可能需要注入一個DLL到游戲進程中去干點什么“壞事”。 但我們知道現在要Inject DLL是越來越難了。場景1:制作火星文輸入法G***,原理是利用API HOOK攔截并修改輸入法相關函數,需要注入一個DLL到所有進程中,但是后來發現,在開啟了瑞星的帳號保險箱后,用戶將不能在QQ中輸入火星文。原因是瑞星保護了QQ進程,禁止對其Inject DLL,解決方法是提示用戶關閉帳號保險箱 -_-|? 確實是很降低用戶體驗的一個不是辦法的辦法。場景2:制作某游戲G***,需要注入一個DLL到游戲進程中去直接調用游戲函數完成某一功能。結果發現該游戲有NP保護,OpenProcess打不開,創建遠程線程也不行,試用其它方法也一一失敗。遇到上面的情況,高手們自然是轉到Ring0下面去,使用驅動之類的辦法來對付啦,不過吾等菜鳥可就是酒井沒法子了 -_-|
??? 不過也別太灰心,凡事總會有辦法的。我想我們需要一種持久的、穩定的、不容易被安全軟件屏蔽的DLL注入方法,后來發現,輸入法程序就是能完成這一任務的理想人選。輸入法程序程序到底是什么?它沒有自己的進程,并且在系統還沒有登錄時就已被加載(在歡迎界面你也可以調出輸入法),它可以在游戲中打開,也可以在控制臺程序中打開,還可以在瑞星保護下的QQ中打開,在殺軟中也可以打開,這不就是我們要找的特性嗎。那么,輸入法到底是什么呢?根據Windows的規定,輸入法其實就是一個DLL,不過它是一個特殊的DLL,它必須具有標準輸入法程序所規定的那些接口,輸入法是由輸入法管理器(imm32.dll)控制的,輸入法管理器又是由user32.dll控制的。輸入法在系統目錄是以IME為擴展名的文件,當在應用程序中激活某個輸入法時,輸入法管理器就會在那個應用程序的進程中加載對應的IME文件,注意,加載IME文件跟加載普通的DLL并沒有本質區別,所以,可以認為,輸入法其實就是注入到應用程序中的一個DLL文件,并且,這種“注入”是不會被殺軟和游戲NP攔截的(至少目前是)。現在,我們已經有了一個Inject DLL的另類方法,那就是利用輸入法。具體流程是這樣,首先制作一個標準輸入法文件,但是這個輸入法并不完成文字輸入工作,它的唯一任務就是用來Inject DLL,所以稱為“服務輸入法”,然后,制作一個控制程序,來控制服務輸入法,當然最后還需要一個用于注入的目標DLL,這樣一共就有3個文件。開始工作后,控制程序首先將服務輸入法安裝到系統中,然后傳遞幾個參數給服務輸入法,參數中包括了需要注入的DLL文件的名稱和路徑,然后,控制程序將服務輸入法設置為系統的默認輸入法,這樣新的程序一打開,服務輸入法就會注入那個程序。當然,在服務輸入法安裝之前打開的程序不會被注入,這時需要向系統中的所有窗口POST一條WM_INPUTLANGCHANGEREQUEST消息,該消息可以在指定窗口中后臺激活服務輸入法,這樣,系統中所有擁有窗口的進程就都被我們的服務輸入法注入了。服務輸入法注入程序之后,就會根據控制程序傳遞過來的參數加載目標DLL,這樣目標DLL也就隨著服務輸入法一同注入到目標程序中了。注意服務輸入法是控制程序用WM_INPUTLANGCHANGEREQUEST消息在所有窗口中自動激活的,如果某個窗口自動激活失敗,你就需要在那個窗口中手工切換到服務輸入法,這樣才能注入進去了。至于注入以后,你就可以在窗口中切換到別的輸入法,這并不會影響已經注入進去的DLL。我將這一套功能制作成一個完整的示例,你可以在在網上下載? 壓縮包中的第6個和第8個文件夾演示了此功能并包含所有源代碼。其中文件imedllhost09.dll就是服務輸入法,運行時會被安裝到系統中,控制程序退出時會自動卸載該輸入法,這樣用戶就不太容易察覺,你還可以重新編譯該輸入法,將名稱改為“中文(中國)”,這樣隱蔽性更好。文件hxwdllwx.dll是演示用的目標DLL,你可以替換成自己的DLL,然后那個exe文件就是控制程序了。輸入法imedllhost09.dll在運行時會被復制到系統目錄并更名為imedllhost09.ime,它導出了2個函數用于控制。在VB中的聲明為:
Public Declare Function IMESetPubString Lib "imedllhost09.ime" (ByVal RunDLLStr As String, ByVal UnloadDll As Long, ByVal loadNextIme As Long, ByVal DllData1 As Long, ByVal DllData2 As Long, ByVal DllData3 As Long) As Long
Public Declare Function IMEClearPubString Lib "imedllhost09.ime" () As Long
其中IMESetPubString用于向輸入法傳遞要注入的DLL等參數。RunDLLStr,要注入的DLL命令和完整路徑。UnloadDll,當輸入法退出時,是否同時卸載目標DLL 0-是,1-否。loadNextIme,當切換至該服務輸入法時,是否直接切換到下一個輸入法(這樣服務輸入法就好像被跳過了,可最小限度影響用戶的輸入法順序) 0-否,1-是。DllData1,DllData2,DllData3是傳遞給目標DLL的回調函數(函數名稱必須為RunDllHostCallBack)的參數,你可以在目標DLL中導出一個函數,名稱為RunDllHostCallBack,這樣當輸入法注入時會調用目標DLL的該回調函數并向其傳遞這3個參數。函數原型為(VC):
DWORD RunDllHostCallBack(DWORD calldata1, DWORD calldata2,DWORD calldata3);
IMEClearPubString函數用于清除輸入法的配置,清除后,輸入法將停止在新的程序中注入目標DLL,但已注入的DLL不會卸載。
好了,利用輸入法來Inject DLL基本上就是這樣了,詳細的用法大家可以看壓縮包中的第8個文件夾,其中服務輸入法是VC寫的,控制程序是VB的,代碼都是有注釋的。測試發現該方法能過目前所有殺軟,也能注入冰刃。當然缺點還是有的,就是目標程序如果不接受輸入法那就沒辦法了,但是現在一般的游戲都不會禁止玩家在里面打字吧,而且殺軟也不能禁止用戶輸入漢字吧,哈哈,所以通用性應該還是蠻好的。

Feedback

# re: Inject DLL by IME  回復  更多評論   

2010-02-10 23:33 by 刀刀
你好哥們,源代碼在哪里下載啊,能發給我嗎?
ctguxp@gmail.com

# re: Inject DLL by IME  回復  更多評論   

2010-06-01 23:42 by ddd
"我將這一套功能制作成一個完整的示例,你可以在在網上下載 壓縮包中的第6個和第8個文件夾演示了此功能并包含所有源代碼。"

請問樓主這個鏈接在哪?
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久精品免费| 亚洲电影免费观看高清完整版| 国产精品乱码一区二区三区 | 9l视频自拍蝌蚪9l视频成人| 国产精品久久久久久久久久免费| 久久这里只有精品视频首页| 国产精品色婷婷| 亚洲国产精品福利| 国产精品欧美久久久久无广告| 玖玖精品视频| 欧美高清一区| 亚洲国产另类久久久精品极度| 亚洲黄页一区| 激情六月婷婷久久| 看欧美日韩国产| 欧美日韩一卡二卡| 亚洲国产高清一区| 亚洲午夜国产成人av电影男同| 中文在线一区| 正在播放欧美视频| 欧美成人综合网站| 国产精品综合| 久久黄色小说| 欧美在线黄色| 亚洲国产精品黑人久久久| 亚洲日韩第九十九页| 亚洲国产精品欧美一二99| 欧美在线视频导航| 久久综合五月天婷婷伊人| 国产一区二区三区视频在线观看| 亚洲欧美日韩高清| 免费中文字幕日韩欧美| 久久久午夜视频| 欧美sm极限捆绑bd| 午夜精品影院| 国产字幕视频一区二区| 亚洲愉拍自拍另类高清精品| aaa亚洲精品一二三区| 国产精品蜜臀在线观看| 亚洲国产婷婷综合在线精品| 亚洲欧美精品一区| 欧美日韩国产不卡在线看| 久久精品国产亚洲高清剧情介绍| 蜜桃av噜噜一区| 亚洲电影观看| 91久久精品www人人做人人爽| 亚洲国产精品久久久久婷婷884| 欧美视频在线一区二区三区| 欧美成人久久| 在线看成人片| 夜夜爽www精品| 韩国在线一区| 国产自产女人91一区在线观看| 亚洲一区二区三区涩| 亚洲欧美日韩一区二区| 一区二区三区视频观看| 亚洲专区一二三| 亚洲一区二区三区在线看| 久久久久成人精品| 久久久久国产精品一区| 欧美成人免费在线| 久久精品一区二区三区中文字幕| 欧美日韩在线免费| 亚洲一区二区在线免费观看| 麻豆亚洲精品| 午夜精品婷婷| 午夜天堂精品久久久久| 伊人久久亚洲美女图片| 久久不射网站| 亚洲一区久久| av成人免费| 欧美黄网免费在线观看| 久久久久久亚洲精品中文字幕| 国产日韩视频| 伊人天天综合| 国产日产欧产精品推荐色| 欧美人与禽性xxxxx杂性| 国产亚洲a∨片在线观看| 一本到12不卡视频在线dvd| 国产日韩欧美精品一区| 国产日韩高清一区二区三区在线| 尤妮丝一区二区裸体视频| 亚洲日韩成人| 欧美在线观看一区二区| 亚洲嫩草精品久久| 你懂的国产精品| 国产精品揄拍500视频| 国产精品羞羞答答xxdd| 欧美精品三级在线观看| 亚洲第一精品福利| 亚洲第一在线| 开心色5月久久精品| 亚洲美洲欧洲综合国产一区| 亚洲激情视频网| 性8sex亚洲区入口| 欧美视频在线观看免费网址| 久久久水蜜桃| 欧美激情视频在线播放| 噜噜噜噜噜久久久久久91| 国产片一区二区| 亚洲国产美女| 最近中文字幕日韩精品| 羞羞答答国产精品www一本 | 久久尤物电影视频在线观看| 欧美高清不卡| 夜夜夜久久久| 欧美精品一区二区三| 影音先锋久久精品| 欧美顶级艳妇交换群宴| 午夜精品久久久久久久| 午夜在线一区二区| 欧美精品在线一区二区| av成人动漫| 亚洲激情校园春色| 亚洲精品视频啊美女在线直播| 久久艳片www.17c.com| 美日韩在线观看| 国产精品亚洲一区| 亚洲精品国产精品国自产在线 | 亚洲一区欧美激情| 国产精品扒开腿做爽爽爽视频 | 欧美日韩精品免费观看视一区二区 | 久久在线播放| 亚洲高清自拍| 亚洲天堂av在线免费观看| 中日韩美女免费视频网址在线观看| 亚洲精选中文字幕| 国产精品亚洲综合一区在线观看| 亚洲综合成人在线| 亚洲砖区区免费| 欧美激情成人在线视频| 老鸭窝毛片一区二区三区| 欧美成人第一页| 亚洲精选在线观看| 亚洲一区三区电影在线观看| 欧美激情二区三区| 免费国产一区二区| 国产精品久久久久久一区二区三区| 中国日韩欧美久久久久久久久| 午夜精品久久久久久久99热浪潮| 国产精品99久久久久久www| 欧美亚洲一区在线| 欧美1区2区| 欧美gay视频| 亚洲欧美日韩综合aⅴ视频| 国产精品99久久久久久久久久久久| 国产精品99久久久久久有的能看 | 欧美激情1区2区3区| 午夜精品在线看| 国产精品有限公司| 亚洲国产一区二区在线| 精品va天堂亚洲国产| 欧美黄色小视频| 国产伦精品一区二区三| 亚洲国产欧美一区二区三区丁香婷| 国语自产精品视频在线看一大j8| 亚洲欧美日韩第一区| 蜜臀av一级做a爰片久久| 久久久久久精| 欧美精品久久久久久久久久| 一本色道**综合亚洲精品蜜桃冫 | 欧美色精品天天在线观看视频| 亚洲小说欧美另类婷婷| 久久久久www| 欧美r片在线| 国产综合精品一区| 久久国产日本精品| 欧美一区二区大片| 欧美日韩情趣电影| 亚洲高清视频一区二区| 亚洲综合日韩中文字幕v在线| 一本久久综合| 亚洲欧美久久久久一区二区三区| 亚洲欧美日韩一区| 你懂的国产精品| 久久裸体艺术| 久久久久久久欧美精品| 亚洲视频网站在线观看| 一区二区在线视频观看| 欧美日韩国产123| 久久精品99久久香蕉国产色戒| 欧美日本一区| 亚洲破处大片| 亚洲私人影院| 国产视频精品xxxx| 麻豆成人在线播放| 日韩视频―中文字幕| 亚洲欧美日韩精品| 亚洲欧美国产精品桃花| 国产欧美日韩综合| 久久www成人_看片免费不卡| 亚洲国产合集| 欧美在线一区二区三区| 国产精品一级二级三级| 欧美暴力喷水在线| 欧美日本国产精品| 国产精品国产成人国产三级| 亚洲欧美三级伦理| 亚洲第一综合天堂另类专| 一区二区三区精密机械公司|