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

c++初學(xué)者

專注技術(shù)開發(fā)

[轉(zhuǎn)]怎樣將自己的DLL加載到Explorer.exe

我們知道將動態(tài)連接庫注入到其他進(jìn)程中有很多種方法。最常見的方法是使用鉤子函數(shù)(Hook),但是這種方法主要有兩個缺點(diǎn):第一如果某個進(jìn)程沒有加載User32.dll,那么Hook DLL將永遠(yuǎn)也不會被加載。第二Hook DLL加載的時機(jī)問題,只有在進(jìn)程發(fā)出User32調(diào)用的時候, Hook DLL才有可能被加載。也就是說假設(shè)進(jìn)程正在進(jìn)行復(fù)雜的數(shù)值計(jì)算而沒有時間進(jìn)行消息調(diào)用的時候,Hook DLL是不會被加載。理論上我們沒有精確的辦法來確定我們的Hook DLL是否已經(jīng)注入到我們想要的進(jìn)程中。另外一種最常見的方法是使用函數(shù)CreateRemoteThread,在其他進(jìn)程中開啟一個線程來裝載DLL。應(yīng)該說這是一種比較完美的解決放案,這種方法避免了上述使用鉤子函數(shù)的所有缺點(diǎn),但是遺憾的是這個函數(shù)只能使用在WinNT/2000下。





  本文將討論一種將動態(tài)連接庫注入到其他進(jìn)程中的一種新方法。它的思路與使用函數(shù)CreateRemoteThread的方法相類似,只不過可以使用在Win9x,Win2k,WinXP等操作系統(tǒng)下。在這里我們將向讀者演示我們是如何將DLL(InjectDll.dll)注入到Explorer.exe進(jìn)程中!





程序的思路如下

1:得到Explorer.exe進(jìn)程中任意一個線程的ID.

2:根據(jù)這個線程的ID,得到這個線程的句柄Handle

3:掛起這個線程,并保存線程當(dāng)前的“上下文”

4:改變這個線程的EIP指針,使它指向我們裝載DLL的函數(shù)(InjectCodeFun),然后恢復(fù)這個線程。

5:我們的裝載DLL的函數(shù)運(yùn)行完成后,再次掛起這個線程,使用我們以前保存的“上下文”,恢復(fù)這個線程到它被改變前的狀態(tài),并繼續(xù)運(yùn)行。

經(jīng)過上述幾個步驟,Explorer.exe進(jìn)程中就會替我們裝載我們的DLL(InjectDll.dll)了,有趣的是Explorer.exe對此絲毫沒有察覺任何異常 !





下面我們將詳細(xì)解釋一下如何編程實(shí)現(xiàn)上述過程。

步驟1的實(shí)現(xiàn)是很容易的,我們只需要調(diào)用ToolHelp的函數(shù)就可以得到我們所要得,這里我們就不詳細(xì)說明了,請參考源代碼中GetProcessID, GetThreadID 兩個函數(shù)。



步驟2就比較麻煩了,在Win9x中沒有提供一個函數(shù)可以由Thread ID得到Thread Handle(幸運(yùn)的是Win2K提供這種功能)。好在我們在國外一些BBS上可以找到這個函數(shù),它使用了一些未公開的結(jié)構(gòu),本文的目的不是討論這個問題,讀者如果有興趣的話,可以參考我們的源代碼OpenThread2函數(shù)。這個函數(shù)的作用就是傳入一個Thread ID參數(shù)返回相應(yīng)的 Thread Handle。



步驟3 的實(shí)現(xiàn)也是很容易和規(guī)范的,我們可以用SuspendThread,GetThreadContext等SDK函數(shù)輕松完成。



步驟4 這個步驟是最重要的步驟了。為了說明方便,我們將引用我們源代碼中的語句,請讀者參考源代碼中InjectCodeIntoThread 函數(shù)。

首先改變線程的EIP指針,我們可以用下列代碼完成

ThreadContext.Eip = (DWORD)m_lpCodeBase;

SetThreadContext(m_hInjectThread,&ThreadContext);

變量m_lpCodeBase指向我們的裝載DLL的函數(shù)(InjectCodeFun)的首地址。

這里最關(guān)鍵的部分是我們?nèi)绾萎a(chǎn)生我們的裝載DLL的函數(shù)(InjectCodeFun)。注意我們不能簡單地在我們的程序里寫一個函數(shù),然后將它的首地址賦值給EIP。這是因?yàn)檠b載DLL的函數(shù)是要運(yùn)行在Explorer.exe地址空間中的,如果我們使用自己地址空間中的函數(shù)的話,那么必然會導(dǎo)致系統(tǒng)崩潰。解決的辦法是將我們寫的裝載DLL函數(shù)(InjectCodeFun)放在所有程序共享的地址空間中去,在Win9x中0x80000000 ~ 0xFFFFFFFF這段地址就是我們想要的共享地址空間,那么如何將我們寫的裝載DLL函數(shù)放在這段地址空間呢 ?方法有很多,我們使用一種規(guī)范的方法“內(nèi)存映像文件”來解決這個問題。我們通過函數(shù)CreateFileMapping來分配一段共享地址空間,然后將我們寫的裝載DLL函數(shù)拷貝到這段地址空間中去。具體代碼請參源代碼中InitInject函數(shù)。

在我們寫的裝載DLL函數(shù)(InjectCodeFun)中還有兩個問題我們需要解釋一下,第一 在這個函數(shù)中我們不能使用任何我們自己程序中定義的變量,道理跟上面講的一樣,因?yàn)榈刂房臻g不同。還有我們不能直接調(diào)用函數(shù),例如在InjectCodeFun中直接使用LoadLibray。這是因?yàn)槿绻苯邮褂肔oadLibray那么就需要經(jīng)過程序的Import表,跳轉(zhuǎn)一下才能到達(dá)真正的Windows的LoadLibray函數(shù)。但是不同的進(jìn)程有不同的Import,所以我們不能直接調(diào)用函數(shù)。我們可以使用一種叫做“動態(tài)構(gòu)造函數(shù)”的技術(shù)來創(chuàng)建我們的函數(shù)。首先用GetProcAddress得到函數(shù)LoadLibray的直接地址,然后在調(diào)用LoadLibray的地方,使用一個特殊的數(shù)字來代替它如 0x11111111,最后在將我們的函數(shù)拷貝到共享地址空間之后,搜索共享內(nèi)存找到這個特殊數(shù)字,用我們先前得到的正確地址替換它既可。第二個有趣的現(xiàn)象是我們所寫的裝載DLL函數(shù)(InjectCodeFun)是不應(yīng)該返回的。這是因?yàn)檫@個函數(shù)是在Explorer的線程中運(yùn)行的,我們不知道堆棧的正確內(nèi)容,不知道ESP所指向的地址是什么,如果函數(shù)返回的話,我們將失去對程序的控制。我們的辦法是,當(dāng)調(diào)用完LoadLibray之后,向我們的主程序發(fā)送一個自定義消息,通告我們的程序已經(jīng)完成裝載任務(wù),然后讓線程進(jìn)入死循環(huán)狀態(tài)。



步驟5當(dāng)我們的程序接受到了自定義消息后,就會再次掛起這個線程,把我們以前保存的線程的“上下文”用函數(shù)SetThreadContext恢復(fù),然后恢復(fù)運(yùn)行這個線程。結(jié)果是Explorer.exe絲毫沒有感覺到自己被中斷過。





以上就是我們所介紹的方法,讀者可以參考我們的源代碼來具體了解上述方法。源代碼的功能是將我們的DLL(InjectDll.dll)注入到Explorer.exe 中,在InjectDll.dll中我們創(chuàng)建了一個新的線程,然后在屏幕的左上角顯示當(dāng)前的時間。源代碼分為Win9x版本和Win2k版本,這兩個版本的主要差別是分配共享內(nèi)存的方法不同而已。源代碼已經(jīng)在PWn98,PwinMe,Win2k,WinXP等操作系統(tǒng)下,使用VC6編譯通過。

posted on 2008-09-28 11:34 大海 閱讀(2129) 評論(0)  編輯 收藏 引用 所屬分類: VC++

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            99ri日韩精品视频| 欧美在线亚洲一区| 欧美精品v日韩精品v国产精品| 在线观看一区| 欧美国产日韩在线| 欧美国产极速在线| 亚洲主播在线播放| 亚洲免费在线视频| 尤物精品在线| 亚洲国产一区视频| 欧美破处大片在线视频| 亚洲欧美日韩国产中文 | 亚洲激情在线视频| 亚洲肉体裸体xxxx137| 欧美日韩在线一区二区| 欧美一区二区在线| 久久综合导航| 亚洲一区美女视频在线观看免费| 亚洲一区在线直播| 亚洲福利国产| 亚洲视频在线观看一区| 伊人成人网在线看| 一区二区不卡在线视频 午夜欧美不卡在 | 欧美专区亚洲专区| 亚洲人成网站色ww在线| 亚洲午夜电影| 亚洲国产成人精品视频| 中文久久精品| 亚洲国产专区校园欧美| 亚洲自拍都市欧美小说| 亚洲精品国产精品久久清纯直播| 亚洲尤物在线视频观看| 最新日韩欧美| 欧美中在线观看| 一区二区三区三区在线| 久久久久国产精品一区二区| 99在线视频精品| 久久亚洲国产成人| 久久精品国产亚洲高清剧情介绍| 欧美精品电影| 麻豆成人综合网| 国产日韩专区在线| 在线一区二区三区做爰视频网站 | 欧美日本不卡| 欧美成年视频| 国内自拍一区| 亚洲一级特黄| 亚洲自拍偷拍麻豆| 欧美伦理影院| 亚洲国产视频直播| 亚洲国产cao| 久久久国产精品一区| 欧美一级在线视频| 欧美午夜久久久| 日韩亚洲综合在线| 99成人免费视频| 欧美成人激情视频| 欧美国产精品中文字幕| 亚洲第一区中文99精品| 久久久久国产一区二区三区| 久久久久.com| 狠狠色狠狠色综合日日小说| 性一交一乱一区二区洋洋av| 久久aⅴ国产欧美74aaa| 国产欧美精品日韩精品| 亚洲欧美日韩精品综合在线观看| 亚洲欧美变态国产另类| 国产精品国产自产拍高清av王其| 99re66热这里只有精品4| 在线视频精品一| 欧美涩涩网站| 中文久久精品| 欧美在线日韩在线| 国产伊人精品| 麻豆av福利av久久av| 欧美成人午夜视频| 亚洲精品麻豆| 欧美午夜无遮挡| 亚洲永久免费av| 久久久国际精品| 一区二区三区亚洲| 欧美国产激情二区三区| 亚洲最新合集| 久久精品中文字幕免费mv| 激情丁香综合| 欧美另类在线观看| 亚洲专区一区二区三区| 久久噜噜亚洲综合| 亚洲精品中文字幕女同| 国产精品高潮久久| 久久不见久久见免费视频1| 欧美成人亚洲成人日韩成人| 日韩亚洲欧美高清| 国产麻豆综合| 免费看黄裸体一级大秀欧美| 99国产精品99久久久久久| 性做久久久久久| 亚洲激情网站| 国产精品入口66mio| 久久综合九色欧美综合狠狠| 在线亚洲国产精品网站| 久久亚洲综合色| 一二三区精品| 国内精品久久国产| 欧美日本在线| 久久久久久综合| 一区二区三区视频观看| 麻豆精品视频在线观看| 亚洲免费视频网站| 在线精品国产欧美| 国产精品视频导航| 欧美黄色影院| 久久久久免费视频| 亚洲一区二区三区视频播放| 亚洲二区精品| 久久免费视频网站| 亚洲自拍另类| 亚洲精品视频二区| 精品成人在线视频| 国产精品一区二区三区久久 | 欧美一区二区高清在线观看| 亚洲日本中文字幕免费在线不卡| 久久婷婷丁香| 久久大综合网| 亚洲欧美日韩另类| 一区二区三区日韩| 亚洲伦伦在线| 亚洲福利视频网| 一色屋精品视频在线看| 国产视频在线观看一区二区三区| 国产精品www网站| 欧美日韩福利视频| 欧美成人午夜影院| 美女任你摸久久| 久久免费高清视频| 欧美在线视频免费| 欧美亚洲免费| 性亚洲最疯狂xxxx高清| 亚洲欧美在线一区二区| 亚洲男同1069视频| 亚洲一区一卡| 亚洲欧美中文另类| 亚洲欧美日韩专区| 午夜视频在线观看一区二区| 亚洲自拍高清| 欧美一级成年大片在线观看| 香蕉久久夜色精品| 欧美一级片久久久久久久| 欧美在线高清| 久久综合狠狠| 欧美黄色大片网站| 欧美日韩第一区日日骚| 国产精品videosex极品| 国产精品另类一区| 国产欧美日韩在线播放| 国产视频一区在线观看| 红桃视频欧美| 亚洲人成在线播放| 日韩视频国产视频| 亚洲天堂免费在线观看视频| 亚洲欧美日韩一区二区在线 | 日韩视频精品在线观看| 夜夜狂射影院欧美极品| 亚洲综合999| 久久精品国产一区二区三区| 欧美不卡在线视频| 欧美日韩精品一区二区| 亚洲国产日韩欧美综合久久| 欧美诱惑福利视频| 久久久蜜桃精品| 欧美成人午夜免费视在线看片| 亚洲大片精品永久免费| 日韩小视频在线观看| 亚洲视频一二区| 久久久国产精品一区二区中文| 乱中年女人伦av一区二区| 欧美日韩一区二区三区在线观看免| 国产精品午夜春色av| 亚洲国产精品久久人人爱蜜臀 | 一本色道久久综合亚洲精品小说 | 亚洲精品国久久99热| 亚洲欧美日韩区| 欧美高清在线| 亚洲一区在线直播| 欧美成人免费一级人片100| 国产精品久久久久久久久果冻传媒| 国内精品视频在线播放| 一本色道久久综合亚洲精品按摩 | 欧美成人视屏| 亚洲综合视频1区| 欧美成人激情视频免费观看| 国产伦一区二区三区色一情| 日韩一区二区精品在线观看| 久久精品在线观看| 一区二区三区欧美在线观看| 久久午夜电影| 国产亚洲精品久久久久久| 在线亚洲自拍| 亚洲激情在线观看视频免费| 久久国产精品黑丝|