ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

c语言钩取函数 并奉上使用实例 2021-04-08 110

2021-04-05 21:32:56  阅读:267  来源: 互联网

标签:lpflOldProtect 04 HMODULE 08 TCHAR 钩取 API APIAddr DWORD


运行环境: Windows 7 32位  Visual Studio 2010

/**

名称:hookByCode

功能: 在某个API下钩子

参数:TCHAR * moduleName 模块名 TCHAR * funcName 函数名  PVOID hookProc 钩子函数

返回值:PBYTE 返回被下钩子的API的前5个字节 用于脱钩

**/

PBYTE hookByCode(TCHAR * moduleName,TCHAR * funcName,PVOID hookProc){

//获取API函数地址

PVOID APIAddr = getAPIAddress(moduleName,funcName);

//保存API前五个字节

BYTE pBuf[5] = {0,};

memcpy(pBuf,APIAddr,5);

//计算跳转距离

//目标位置

DWORD desPos = (DWORD)hookProc;

//源位置

DWORD srcPos = (DWORD)APIAddr+5;

DWORD jmpDistance = desPos-srcPos;

//取得可写权限

DWORD lpflOldProtect;

VirtualProtect(APIAddr,5,PAGE_READWRITE,&lpflOldProtect);

//设置跳转语句

memcpy((byte *)APIAddr+1,&jmpDistance,4);

*(BYTE *)APIAddr = 0xE9;

VirtualProtect(APIAddr,5,lpflOldProtect,&lpflOldProtect);

return pBuf;

}

HMODULE myload(LPCSTR lpLibFileName){

printf("惊喜吗!!!");

return 0;

}

void main(){

hookByCode(L"kernel32.dll",L"LoadLibraryA",myload);  //让LoadLibray被myload函数取代

HMODULE load = LoadLibraryW(L"kernel32.dll");

HMODULE (*loadW)(LPCSTR);

loadW = (HMODULE (*)(LPCSTR))GetProcAddress(load,"LoadLibraryA");

loadW("d");

}

结果图:


 

标签:lpflOldProtect,04,HMODULE,08,TCHAR,钩取,API,APIAddr,DWORD
来源: https://www.cnblogs.com/czlnb/p/14619543.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有