• <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>

            S.l.e!ep.¢%

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

            Inject DLL by IME

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

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

            Feedback

            # re: Inject DLL by IME  回復(fù)  更多評(píng)論   

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

            # re: Inject DLL by IME  回復(fù)  更多評(píng)論   

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

            請(qǐng)問(wèn)樓主這個(gè)鏈接在哪?
            久久无码精品一区二区三区| 久久久久久国产精品免费无码 | 国产成人精品久久| 99热都是精品久久久久久| 久久久久人妻一区精品| 精品久久久久久久国产潘金莲| 新狼窝色AV性久久久久久| 2021久久国自产拍精品| 国产成人精品久久一区二区三区av | 久久久国产精品福利免费 | 无码AV中文字幕久久专区| 国产精品久久久久影院色| 久久精品成人一区二区三区| 久久精品视频一| 狠狠狠色丁香婷婷综合久久俺| 久久精品无码一区二区日韩AV| 久久精品国产AV一区二区三区 | 一极黄色视频久久网站| 97热久久免费频精品99| 久久久噜噜噜久久| 99re这里只有精品热久久| 亚洲精品99久久久久中文字幕| www久久久天天com| 久久久久亚洲AV片无码下载蜜桃| 国内精品久久久久久99蜜桃| 久久久久婷婷| 久久精品国产一区| 亚洲国产欧美国产综合久久| 九九热久久免费视频| 久久成人国产精品| 久久久久se色偷偷亚洲精品av| 久久精品国产免费一区| 亚洲AV日韩AV永久无码久久| 久久影院午夜理论片无码| 91精品国产综合久久婷婷| 久久笫一福利免费导航 | 波多野结衣中文字幕久久| 国产精品成人久久久| 久久久无码精品午夜| 国产精品欧美久久久久天天影视| 久久婷婷五月综合色高清|