真香定律:MiniHook+Remote DLL

windows的函數(shù)hook大致分為2類(lèi):指定進(jìn)程Hook和系統(tǒng)全局(system-wide)Hook辑甜。指定進(jìn)程的Hook常規(guī)思路是先編寫(xiě)一個(gè)hook指定函數(shù)的dll雾消,然后使用dll注入打到指定進(jìn)程荸恕。系統(tǒng)全局Hook一般采用AppInit DLLs方案猴誊,這大概是最簡(jiǎn)單做全局dll注入的方案了艰赞,很明顯微軟也意識(shí)到了這個(gè)弱點(diǎn)莱褒,在win10上面開(kāi)始對(duì)AppInit DLLs進(jìn)行限制浴栽,參考 AppInit_Dlls鍵值 和 微軟官方文檔 AppInit DLLs and Secure Boot荒叼。本文將使用MiniHook模塊實(shí)現(xiàn)指定進(jìn)程Hook。

代碼背景:朋友從某個(gè)論壇買(mǎi)了一個(gè)教程典鸡,但是論壇給了指定播放器被廓。導(dǎo)致每次播放時(shí)需要聯(lián)網(wǎng)驗(yàn)證,而且檢測(cè)到開(kāi)啟屏幕錄像軟件后就將其殺掉椿每。首先使用API Logger對(duì)播放器進(jìn)程進(jìn)行函數(shù)調(diào)用跟蹤伊者,發(fā)現(xiàn)該播放器使用CreateToolhelp32Snapshot枚舉進(jìn)程,當(dāng)發(fā)現(xiàn)是屏幕錄像軟件時(shí)則使用OpenProcess和TerminateProcess殺死進(jìn)程间护。解決思路為Hook 播放器進(jìn)程的OpenProcess函數(shù)亦渗,當(dāng)嘗試打開(kāi)非當(dāng)前進(jìn)程時(shí)直接返回?zé)o效句柄。

  1. 使用MiniHook Hook OpenProcess函數(shù)
#include <iostream>
#include "MinHook.h"

typedef HANDLE (WINAPI *OpenProcessFunc)(DWORD ,BOOL ,DWORD );
OpenProcessFunc pfOpenProcess = NULL;

HANDLE WINAPI FuckOpenProcess(DWORD dwDesiredAccess,BOOL  bInheritHandle,DWORD dwProcessId)
{
    if (dwProcessId == GetCurrentProcessId())
    {
        return (pfOpenProcess)(dwDesiredAccess, bInheritHandle, dwProcessId);
    }
    else   // 當(dāng)嘗試打開(kāi)其他進(jìn)程時(shí)直接返回空句柄
    {
        SetLastError(ERROR_ACCESS_DENIED);
        return INVALID_HANDLE_VALUE;
    }
}

BOOL APIENTRY DllMain(HMODULE hModule, DWORD url_for_reason, LPVOID lpReserved)
{
    switch (url_for_reason)
    {
    case DLL_PROCESS_ATTACH:
        {
            MH_Initialize();
            MH_CreateHookApi(L"Kernel32", "OpenProcess", &FuckOpenProcess, (LPVOID*)&pfOpenProcess);
            MH_EnableHook(&OpenProcess);
            break;
        }
    case DLL_PROCESS_DETACH:
        {
            MH_DisableHook(&OpenProcess);
            MH_Uninitialize();
            break;
        }
    }
    return TRUE;
}
  1. 使用Remote DLL進(jìn)行進(jìn)程注入
    Remote DLL下載地址: https://securityxploded.com/remotedll.php
    使用截圖如下:
    remote dll
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末汁尺,一起剝皮案震驚了整個(gè)濱河市法精,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌痴突,老刑警劉巖搂蜓,帶你破解...
    沈念sama閱讀 210,835評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異辽装,居然都是意外死亡帮碰,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,900評(píng)論 2 383
  • 文/潘曉璐 我一進(jìn)店門(mén)拾积,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)殉挽,“玉大人丰涉,你說(shuō)我怎么就攤上這事∷孤担” “怎么了一死?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,481評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)傻唾。 經(jīng)常有香客問(wèn)我投慈,道長(zhǎng),這世上最難降的妖魔是什么冠骄? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,303評(píng)論 1 282
  • 正文 為了忘掉前任伪煤,我火速辦了婚禮,結(jié)果婚禮上猴抹,老公的妹妹穿的比我還像新娘带族。我一直安慰自己,他們只是感情好蟀给,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,375評(píng)論 5 384
  • 文/花漫 我一把揭開(kāi)白布蝙砌。 她就那樣靜靜地躺著,像睡著了一般跋理。 火紅的嫁衣襯著肌膚如雪择克。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,729評(píng)論 1 289
  • 那天前普,我揣著相機(jī)與錄音肚邢,去河邊找鬼。 笑死拭卿,一個(gè)胖子當(dāng)著我的面吹牛骡湖,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播峻厚,決...
    沈念sama閱讀 38,877評(píng)論 3 404
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼响蕴,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了惠桃?” 一聲冷哼從身側(cè)響起浦夷,我...
    開(kāi)封第一講書(shū)人閱讀 37,633評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎辜王,沒(méi)想到半個(gè)月后劈狐,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,088評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡呐馆,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,443評(píng)論 2 326
  • 正文 我和宋清朗相戀三年肥缔,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片汹来。...
    茶點(diǎn)故事閱讀 38,563評(píng)論 1 339
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡续膳,死狀恐怖怒见,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情姑宽,我是刑警寧澤,帶...
    沈念sama閱讀 34,251評(píng)論 4 328
  • 正文 年R本政府宣布闺阱,位于F島的核電站炮车,受9級(jí)特大地震影響废麻,放射性物質(zhì)發(fā)生泄漏巾腕。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,827評(píng)論 3 312
  • 文/蒙蒙 一遍膜、第九天 我趴在偏房一處隱蔽的房頂上張望赊豌。 院中可真熱鬧扛或,春花似錦、人聲如沸碘饼。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,712評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)艾恼。三九已至住涉,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間钠绍,已是汗流浹背舆声。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,943評(píng)論 1 264
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留柳爽,地道東北人媳握。 一個(gè)月前我還...
    沈念sama閱讀 46,240評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像磷脯,于是被迫代替她去往敵國(guó)和親蛾找。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,435評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容

  • 參考文獻(xiàn) 逆向工程核心原理 Windows消息勾取 消息鉤子 Windows操作系統(tǒng)向用戶提供GUI争拐,它以事件驅(qū)動(dòng)...
    SamiraG閱讀 346評(píng)論 0 0
  • DLL注入是把指定的DLL加載到另一個(gè)進(jìn)程的內(nèi)存空間中去腋粥。 DLL注入技術(shù):1、通過(guò)遠(yuǎn)程線程注入 ...
    kotw_zjc閱讀 598評(píng)論 0 0
  • cleanmgr--打開(kāi)磁盤(pán)清理工具 compmgmt.msc--計(jì)算機(jī)管理 conf—-啟動(dòng)netmeeting...
    AnHuaFeng閱讀 3,592評(píng)論 0 1
  • 介紹 DLL(Dynamic-link library)注入架曹,即隘冲,把一個(gè)DLL文件放到目標(biāo)進(jìn)程中。當(dāng)一個(gè)進(jìn)程的程序...
    peerless_1024閱讀 588評(píng)論 0 0
  • 黑色的海島上懸著一輪又大又圓的明月,毫不嫌棄地把溫柔的月色照在這寸草不生的小島上万牺。一個(gè)少年白衣白發(fā)罗珍,悠閑自如地倚坐...
    小水Vivian閱讀 3,099評(píng)論 1 5