需要一个API HOOK的实例

希望能是C语言的实例,至于方式是采用更改iat还是jmp先由你们来看看我描述的情况:我需要hook的是系统进程spoolsv.exe中的EndDocPrinter函数。该... 希望能是C语言的实例,
至于方式是采用更改iat还是jmp 先由你们来看看我描述的情况:
我需要hook的是系统进程spoolsv.exe中的EndDocPrinter函数。该进程是系统打印服务程序,我不清楚运行中的程序可不可以通过更改iat来办到
我现在自己还写不出来,网上搜了好多资料,感觉好乱,虽然有点理解大体是咋回事了,可是代码还是写不出来。
希望明白的朋友大至给我说说用C语言调api方式如何实现这个。
就算不给实例,给我说说方案也好
展开
 我来答
可以叫我表哥
2015-08-23 · 知道合伙人数码行家
可以叫我表哥
知道合伙人数码行家
采纳数:25897 获赞数:1464984
2010年毕业于北京化工大学北方学院计算机科学与技术专业毕业,学士学位,工程电子技术行业4年从业经验。

向TA提问 私信TA
展开全部
API HOOK的实例参考如下:
#include <windows.h>
#include "APIHook.h"

extern CAPIHook g_OpenProcess;

// 自定义OpenProcess函数
#pragma data_seg("YCIShared")
HHOOK g_hHook = NULL;
DWORD dwCurrentProcessId=0;
#pragma data_seg()

HANDLE WINAPI Hook_OpenProcess(DWORD dwDesiredAccess, BOOL bInheritHandle, DWORD dwProcessId)
{
typedef HANDLE (WINAPI *PFNTERMINATEPROCESS)(DWORD, BOOL,DWORD);

if(dwProcessId != dwCurrentProcessId)
{
return ((PFNTERMINATEPROCESS)(PROC)g_OpenProcess)(dwDesiredAccess,bInheritHandle,dwProcessId);
}
return 0;
}

// 挂钩OpenProcess函数
CAPIHook g_OpenProcess("kernel32.dll", "OpenProcess",
(PROC)Hook_OpenProcess);

///////////////////////////////////////////////////////////////////////////

static HMODULE ModuleFromAddress(PVOID pv)
{
MEMORY_BASIC_INFORMATION mbi;
if(::VirtualQuery(pv, &mbi, sizeof(mbi)) != 0)
{
return (HMODULE)mbi.AllocationBase;
}
else
{
return NULL;
}
}

static LRESULT WINAPI GetMsgProc(int code, WPARAM wParam, LPARAM lParam)
{
return ::CallNextHookEx(g_hHook, code, wParam, lParam);
}

BOOL WINAPI SetSysHook(BOOL bInstall, DWORD dwThreadId)
{
BOOL bOk;
dwCurrentProcessId=dwThreadId;
if(bInstall)
{
g_hHook = ::SetWindowsHookEx(WH_GETMESSAGE, GetMsgProc,
ModuleFromAddress(GetMsgProc), 0);
bOk = (g_hHook != NULL);
}
else
{
bOk = ::UnhookWindowsHookEx(g_hHook);
g_hHook = NULL;
}
return bOk;
}
匿名用户
2012-02-28
展开全部
KHELPER_API BOOL WINAPI kFixupCallEx(HANDLE hProcess,FARPROC srcproc,FARPROC dstproc,FARPROC *realProc){
char *src=(char*)srcproc;
char *offset=(char*)dstproc;
offset-=*(DWORD*)&srcproc;
//orig nop nop nop nop nop; mov edi,edi
//jmp disp; jmp short -7 (0xf9)
char code[]={'\xe9',0,0,0,0,'\xeb','\xf9'};
memcpy(code+1,&offset,4);

DWORD oldProt;
if(FALSE==VirtualProtectEx(hProcess,src-5,sizeof(code),PAGE_READWRITE,&oldProt)){
ReturnFalse( L"VirtualProtect Failed");
}
if(FALSE==WriteProcessMemory(hProcess,src-5,code,sizeof(code),0)){
ReturnFalse(L"WriteProcessMemory Failed");
}
if(FALSE==VirtualProtectEx(hProcess,src-5,sizeof(code),oldProt,&oldProt)){
ReturnFalse(L"VirtualProtect Failed");
}
if(realProc){
*realProc=(FARPROC)(src+2);
}
return TRUE;
}

KHELPER_API BOOL WINAPI kCleanFixupCallEx(HANDLE hProcess,FARPROC srcproc){
char *src=(char*)srcproc;
//nop nop nop nop nop mov edi,edi
char code[]="\x90\x90\x90\x90\x90\x8b\xff";
DWORD oldProt;
if(FALSE==VirtualProtectEx(hProcess,src-5,sizeof(code),PAGE_READWRITE,&oldProt)){
ReturnFalse( L"VirtualProtect Failed");
}
if(FALSE==WriteProcessMemory(hProcess,src-5,code,sizeof(code),0)){
ReturnFalse(L"WriteProcessMemory Failed");
}
if(FALSE==VirtualProtectEx(hProcess,src-5,sizeof(code),oldProt,&oldProt)){
ReturnFalse(L"VirtualProtect Failed");
}
return TRUE;
}
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式