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

c++初學(xué)者

專(zhuān)注技術(shù)開(kāi)發(fā)

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

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





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





程序的思路如下

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

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

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

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

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

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





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

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



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



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



步驟4 這個(gè)步驟是最重要的步驟了。為了說(shuō)明方便,我們將引用我們?cè)创a中的語(yǔ)句,請(qǐng)讀者參考源代碼中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)。注意我們不能簡(jiǎn)單地在我們的程序里寫(xiě)一個(gè)函數(shù),然后將它的首地址賦值給EIP。這是因?yàn)檠b載DLL的函數(shù)是要運(yùn)行在Explorer.exe地址空間中的,如果我們使用自己地址空間中的函數(shù)的話(huà),那么必然會(huì)導(dǎo)致系統(tǒng)崩潰。解決的辦法是將我們寫(xiě)的裝載DLL函數(shù)(InjectCodeFun)放在所有程序共享的地址空間中去,在Win9x中0x80000000 ~ 0xFFFFFFFF這段地址就是我們想要的共享地址空間,那么如何將我們寫(xiě)的裝載DLL函數(shù)放在這段地址空間呢 ?方法有很多,我們使用一種規(guī)范的方法“內(nèi)存映像文件”來(lái)解決這個(gè)問(wèn)題。我們通過(guò)函數(shù)CreateFileMapping來(lái)分配一段共享地址空間,然后將我們寫(xiě)的裝載DLL函數(shù)拷貝到這段地址空間中去。具體代碼請(qǐng)參源代碼中InitInject函數(shù)。

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



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





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

posted on 2008-09-28 11:34 大海 閱讀(2129) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): 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>
            欧美在线日韩精品| 亚洲人成免费| 99国产精品视频免费观看一公开| 国产亚洲一区二区精品| 亚洲视频导航| 在线视频一区二区| 欧美激情精品久久久久久免费印度| 久久本道综合色狠狠五月| 亚洲天堂网站在线观看视频| 最新成人av网站| 欧美性猛交xxxx乱大交蜜桃 | 久热re这里精品视频在线6| 在线综合亚洲| 欧美成人嫩草网站| 欧美不卡高清| 亚洲国产综合在线看不卡| 久久久久国产精品一区二区| 久久夜色精品国产噜噜av| 国产亚洲精品福利| 久久成人精品无人区| 久久久美女艺术照精彩视频福利播放 | 久久亚洲综合| 国产片一区二区| 亚洲一区二区三区三| 亚洲欧美视频一区| 国产精品视频yy9099| 亚洲免费视频网站| 欧美一区二区三区婷婷月色| 国产美女精品一区二区三区| 欧美一区午夜视频在线观看| 久久久一区二区三区| 狠狠狠色丁香婷婷综合久久五月| 久久精品夜色噜噜亚洲aⅴ| 牛牛国产精品| 日韩视频一区二区三区在线播放免费观看 | 欧美一二三视频| 国产一区在线免费观看| 久久婷婷一区| 最新国产乱人伦偷精品免费网站| 日韩视频一区二区三区在线播放| 欧美绝品在线观看成人午夜影视| 一本一道久久综合狠狠老精东影业| 亚洲一区二区三区四区五区午夜| 国产欧美日韩不卡| 久久精品一区中文字幕| 欧美成人免费在线| 亚洲午夜高清视频| 国产日韩一区二区三区在线播放 | 欧美一二三视频| 免费中文字幕日韩欧美| 99热在这里有精品免费| 国产精品入口尤物| 蜜臀久久99精品久久久画质超高清| 亚洲欧洲另类| 久久久噜噜噜久久中文字免 | 亚洲国产精品第一区二区三区| 欧美激情精品久久久久久大尺度 | 欧美精品在线观看| 亚洲欧美中文在线视频| 欧美激情国产高清| 香蕉久久精品日日躁夜夜躁| 国产一区二区三区精品久久久| 欧美高清不卡| 羞羞答答国产精品www一本| 亚洲国产日韩综合一区| 欧美亚洲一区二区三区| 亚洲精品久久久久久久久久久久| 国产九九视频一区二区三区| 欧美高清视频www夜色资源网| 午夜激情综合网| 亚洲人被黑人高潮完整版| 久久久欧美一区二区| 亚洲欧美久久| 日韩视频不卡中文| 经典三级久久| 国产乱肥老妇国产一区二| 欧美精品三区| 久久尤物电影视频在线观看| 亚洲午夜av电影| 亚洲日韩成人| 亚洲国产精品国自产拍av秋霞| 久久精品男女| 亚洲欧美资源在线| 亚洲午夜免费视频| 亚洲人精品午夜在线观看| 狠狠综合久久| 国产在线国偷精品产拍免费yy| 国产精品video| 欧美裸体一区二区三区| 免费在线日韩av| 久久久精品国产免大香伊| 亚洲视频一二| av不卡在线| 日韩视频在线观看免费| 亚洲国产精品一区二区第四页av | 农夫在线精品视频免费观看| 欧美一区亚洲二区| 欧美一区二区精美| 午夜精品国产| 性欧美超级视频| 午夜在线一区二区| 亚洲无亚洲人成网站77777| 亚洲作爱视频| 亚洲视频香蕉人妖| 亚洲一区二区三区午夜| 亚洲一区二区在线视频 | 久久国产一区二区| 午夜在线a亚洲v天堂网2018| 亚洲欧美日韩中文播放| 午夜精品国产更新| 欧美伊人影院| 久久久久久自在自线| 久久夜色精品国产亚洲aⅴ | 久久中文精品| 美腿丝袜亚洲色图| 欧美精品久久久久久久久老牛影院| 欧美精品xxxxbbbb| 欧美日韩亚洲高清一区二区| 国产精品yjizz| 国产麻豆成人精品| 国内揄拍国内精品久久| 亚洲第一精品福利| 中日韩美女免费视频网址在线观看 | 久久婷婷av| 亚洲国产精品一区| 一本久久精品一区二区| 午夜亚洲一区| 另类人畜视频在线| 欧美四级在线| 韩国免费一区| 一本久久a久久免费精品不卡 | 亚洲一区国产视频| 久久久久久久999精品视频| 欧美不卡在线| 一本久道久久综合婷婷鲸鱼| 欧美一区二区免费| 欧美成人嫩草网站| 国产精品羞羞答答| 亚洲国产精品视频| 亚洲欧美中文日韩在线| 蜜臀av一级做a爰片久久| 亚洲看片免费| 久久99在线观看| 欧美日韩性生活视频| 激情懂色av一区av二区av| 一二三区精品| 美女黄毛**国产精品啪啪| 一区二区激情小说| 久久久久久欧美| 国产精品久久久久久一区二区三区| 狠狠色2019综合网| 亚洲一区二区三区四区五区午夜| 蜜臀久久99精品久久久久久9 | 亚洲人妖在线| 久久精品视频免费| 欧美午夜精品久久久久久孕妇| 黑丝一区二区三区| 午夜亚洲视频| 亚洲美女区一区| 美女网站久久| 国内精品免费在线观看| 亚洲婷婷在线| 亚洲经典视频在线观看| 久久久久久久久伊人| 国产九区一区在线| 亚洲一区二区三区四区在线观看| 欧美电影免费观看高清完整版| 午夜亚洲视频| 国产精品久久午夜| 亚洲午夜精品| 亚洲日本中文字幕免费在线不卡| 久久久久久亚洲精品杨幂换脸| 国产热re99久久6国产精品| 一区二区三区高清视频在线观看| 欧美成人黑人xx视频免费观看| 午夜一级久久| 国产欧美日韩免费| 亚洲欧美精品suv| 一区二区三区视频免费在线观看| 欧美了一区在线观看| 亚洲精品乱码久久久久久日本蜜臀| 嫩草国产精品入口| 久久免费精品日本久久中文字幕| 国产一区二区三区不卡在线观看| 欧美诱惑福利视频| 亚洲欧美日韩精品在线| 国产精品日韩在线| 午夜亚洲福利在线老司机| 亚洲一级片在线看| 国产精品一区二区三区久久| 亚洲综合视频在线| 亚洲视频高清| 国产日韩久久| 久久亚洲精品伦理| 久热精品在线视频| 亚洲欧洲日本专区| 亚洲精品久久久蜜桃| 国产精品国产精品| 欧美在线观看你懂的| 久久精品道一区二区三区|