自实现API, 过所有用户层HOOK

本文转载自:http://blog.csdn.net/u012410612/article/details/17174155
//绕过用户层HOOK,自实现API函数  
//学习了郁金香驱动教学视频 043_绕过所有用户层HOOK(郁金香绕过的是FindWindow)  
//用相同的原理我实现了绕过SendMessageA()  
//实现过程中有一些感想一并记录  
//win xp x86  
//__declspec(naked)作用: 生成纯汇编  
#include <windows.h>  
#include <stdio.h>  
  
//7C92E4F0 >  8BD4             mov edx,esp  
//7C92E4F2    0F34             sysenter  
//7C92E4F4 >  C3               retn  
__declspec(naked) void sysFastCall()  
{  
    _asm  
    {  
        mov edx,esp;    //到达这里时会有堆栈顶是两个返回地址,然后才是参数,貌似每个api都是  
                        //所以定义sysFastCall和SendMyMessageA来模拟堆栈  
        __emit 0x0f;    //sysenter硬编码  
        __emit 0x34;  
    }  
}  
  
//_stdcall 规定参数从右往左依次压栈  
__declspec (naked) LRESULT __stdcall SendMyMessageA(HWND h, UINT Msg, WPARAM wParam, LPARAM lParam)  
{  
    _asm  
    {  
        mov eax,0x11cc;     //内核函数功能号  
        call sysFastCall;  
        retn 0x1c;          //这个必须和API对应相同,也就是说传入内核的参数必须一样,  
                            //内核会严格检验参数个数与有效性  
    }  
}  
  
int main(void)  
{  
    HWND h = FindWindowA(NULL, "计算器");  
    _asm{  
        push 0x01;          //这三个是API调用过程中传入的固定数字  
        push 0x2b0;         //不用WM_CLOSE,用WM_DESTROY也是一样的,所以应该都是一样的吧。。没有每个测试  
        push 0;             //刚好和压入参数个数组成7个参数(retn 0x1c)  
    }  
    SendMyMessageA(h, WM_CLOSE, NULL, NULL);  
    return 0;  
}  


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值