日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

利用detours实现API劫持

發布時間:2024/8/1 编程问答 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 利用detours实现API劫持 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一直想玩黑客技術,今天正好找到一個detours的庫,這是微軟的出品的用來搞這類活動的庫,下載下來,用了一下,把messagebox給劫持了,感覺各種好happy,23333333333
這里需要特別注意的一點是,一定要在release模式下使用,否則是顯示不出效果的。

// ====================== 【API劫持】=========================== // @ author : zhyh2010 // @ date : 20150530 // @ version : 1.0 // @ description : 劫持 系統API 這里以 MessageBox 為例 // 注意 需要預先配置 detours // @ detours 配置 : http://research.microsoft.com/en-us/projects/detours/ // 安裝后, 使用 nmake 編譯源文件,并將相應文件拷貝到工程目錄即可 // 【一定要用release模式編譯 <^-^>】 // =================== 【end of API劫持】========================#include <stdio.h> #include <stdlib.h> #include <windows.h> #include "detours.h" #include "detver.h" #pragma comment(lib, "detours.lib")static int (WINAPI *OldMessageBoxA)( HWND hWnd, LPCWSTR lpText, LPCWSTR lpCaption, UINT uType) = MessageBoxA;int WINAPI NewMessageBoxA( HWND hWnd, LPCWSTR lpText, LPCWSTR lpCaption, UINT uType) {printf("哈哈,你的函數被我劫持了哦<^_^>\n");return 0; }VOID Hook() {DetourRestoreAfterWith();DetourTransactionBegin();DetourUpdateThread(GetCurrentThread());//這里可以連續多次調用DetourAttach,表明HOOK多個函數DetourAttach((void **)&OldMessageBoxA, NewMessageBoxA);DetourTransactionCommit(); }VOID UnHook() {DetourTransactionBegin();DetourUpdateThread(GetCurrentThread());//這里可以連續多次調用DetourDetach,表明撤銷多個函數HOOKDetourDetach((void **)&OldMessageBoxA, NewMessageBoxA);DetourTransactionCommit();}void main() {MessageBoxA(0, "鋤禾日當午1", "學C真辛苦", 0);Hook();MessageBoxA(0, "鋤禾日當午2", "學C真辛苦", 0); }

總結

以上是生活随笔為你收集整理的利用detours实现API劫持的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。