码迷,mamicode.com
首页 > 其他好文 > 详细

Detour的使用

时间:2015-02-12 02:03:03      阅读:358      评论:0      收藏:0      [点我收藏+]

标签:api hook   detour   

最近有用到detour,属于一种api拦截的方式了,是微软研究院出的一个库(可以网上下载,是源码形式,有makefile,可用vs的命令行工具来编译出来)。可以替换掉我们关心的api,进入到我们的处理中。

当然,api拦截,首先需要借助Dll注入,才能够去影响你想改变的进程,这可通过上篇文章中全局hook来实现:可在hookProc回调中,进行detour,然后在DLL的proc_detach中undetour就可以了。

其实detour的使用倒是很简单了。直接几个接口就可以了,具体看下面代码。

static bool _apihooked = false;

static int (WINAPI *SysMessageBox)(HWND hWnd, LPCTSTR lpText, LPCTSTR lpCaption, UINT uType)
= MessageBox;

// detour function that replaces the MessageBox API
int WINAPI HookMessageBox(HWND hWnd, LPCTSTR lpText, LPCTSTR lpCaption, UINT uType)
{
    using namespace std;
    wofstream ofs(L"record.txt", ios::app);
    ofs.write(lpText, _tcslen(lpText));
    ofs.close();
    return SysMessageBox(hWnd, lpText, lpCaption, uType);
}

static bool _detourStart()
{    
    DetourRestoreAfterWith();//

    DetourTransactionBegin();
    DetourUpdateThread(GetCurrentThread());

    DetourAttach(&(PVOID&)SysMessageBox, HookMessageBox);

    LONG ret = DetourTransactionCommit();
    if (ret != NO_ERROR)
    {
        assert(false && "detour start failed");
        return false;
    }

    return true;
}

static bool _detourStop()
{    
    DetourTransactionBegin();
    DetourUpdateThread(GetCurrentThread());

    DetourDetach(&(PVOID&)SysMessageBox, HookMessageBox);

    LONG ret = DetourTransactionCommit();
    if (ret != NO_ERROR)
    {
        assert(false && "detour stop failed");
        return false;
    }

    return true;
}

bool DetourStart()
{
    if (!_apihooked)
    {
        if (!_detourStart())
            return false;
        _apihooked = true;
    }

    return true;
}

bool DetourStop()
{
    if (_apihooked)
    {
        if (!_detourStop())
            return false;
        _apihooked = false;
    }

    return true;
}


本文出自 “v” 博客,请务必保留此出处http://4651077.blog.51cto.com/4641077/1613842

Detour的使用

标签:api hook   detour   

原文地址:http://4651077.blog.51cto.com/4641077/1613842

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!