开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 2896|回复: 5
收起左侧

[已回应] ApiHook,改进建议。

[复制链接]
结帖率:82% (9/11)
发表于 2016-4-10 00:03:51 | 显示全部楼层 |阅读模式   广东省深圳市
本帖最后由 萧阳天 于 2016-4-10 01:46 编辑

模块的APIHOOK方法,过于复杂不易管理,且效率偏低还存在安全问题(程序执行环境),对此稍做改进,希望采纳。


改进的HOOK,支持任意API,或者其它模块的导出函数的拦截,不需要担心寄存器的保存以及堆栈问题,并且可以直接调用被HOOK的函数(通过声明一个新的
子程序交由HOOK函数进行编码,这使得你可以在拦截函数中直接调用原函数而不需要将你的HOOK钩子取消)

Hook效果:

无标题.jpg

  
子程序名返回值类型公开备 注
_启动子程序整数型 请在本子程序中放置易模块初始化代码
SetApiHook (“user32.dll”, “MessageBoxA”, &NewMessageBoxA, &JmpMessageBoxA, , )
标准输入 ()
信息框 (“测试函数”, 0, , )
标准输入 ()
_临时子程序 ()  ' 在初始化代码执行完毕后调用测试代码
返回 (0)  ' 可以根据您的需要返回任意数值
子程序名返回值类型公开备 注
NewMessageBoxA整数型 
参数名类 型参考可空数组备 注
hWnd整数型
lpText整数型
lpCaption整数型
uType整数型
' 在回调函数中,完全不用担心寄存器环境,以及堆栈平衡问题,就像在调用你自己的子程序一样
调试输出 (“消息框文本”, 指针到文本 (lpText))
返回 (JmpMessageBoxA (hWnd, lpText, lpCaption, uType))
子程序名返回值类型公开备 注
JmpMessageBoxA整数型 
参数名类 型参考可空数组备 注
hWnd整数型
lpText整数型
lpCaption整数型
uType整数型
返回 (0)
子程序名返回值类型公开备 注
_临时子程序  
' 本名称子程序用作测试程序用,仅在开发及调试环境中有效,编译发布程序前将被系统自动清空,请将所有用作测试的临时代码放在本子程序中。 ***注意不要修改本子程序的名称、参数及返回值类型。
子程序名返回值类型公开备 注
SetApiHook逻辑型 
参数名类 型参考可空数组备 注
szModule文本型
szApiName文本型
lpfnHookAddress子程序指针用于接管目标函数的子程序
lpfnNewApiAddress子程序指针用于调用原目标的子程序
dwSize整数型安装长度
bSwArginfo逻辑型是否有参数
变量名类 型静态数组备 注
theApiAddress整数型 
theSubPtr整数型 
theJumpPtr整数型 
theRetVal整数型 
theSaveSize整数型 
theDevAddress整数型 
theOldProtect整数型 
theOldProtect2整数型 
theApiAddress = GetProcAddress (LoadLibraryA (szModule), szApiName)
theSubPtr = 到整数 (lpfnHookAddress)
theJumpPtr = ToCallback (lpfnNewApiAddress, bSwArginfo) + 3
theSaveSize = 选择 (dwSize = 0, 5, dwSize)
如果真 (theApiAddress ≠ 0)
theDevAddress = theApiAddress - theSubPtr
theDevAddress = 位取反 (theDevAddress)
theDevAddress = theDevAddress - 4
如果真 (VirtualProtect (theApiAddress, theSaveSize, #PAGE_EXECUTE_READWRITE, theOldProtect) VirtualProtect (theJumpPtr, theSaveSize, #PAGE_EXECUTE_READWRITE, theOldProtect2))
如果真 (theSaveSize > 5)
memcpy (theJumpPtr, theApiAddress, theSaveSize)
memset (theApiAddress + 5, 144, theSaveSize - 5)  ' 填充nop
theSaveSize = theSaveSize - 5
Xcode (theApiAddress, 0, 233, #XCODE_WRITE_BYTE )
Xcode (theApiAddress, 1, theDevAddress, #XCODE_WRITE_DWORD )
theDevAddress = theJumpPtr + theSaveSize (theApiAddress + 5)
theDevAddress = 位取反 (theDevAddress)
theDevAddress = theDevAddress - 4
Xcode (theJumpPtr, theSaveSize, 233, #XCODE_WRITE_BYTE )
Xcode (theJumpPtr, theSaveSize + 1, theDevAddress, #XCODE_WRITE_DWORD )
VirtualProtect (theApiAddress, theSaveSize, theOldProtect, 0)
VirtualProtect (theJumpPtr, theSaveSize, theOldProtect2, 0)
返回 ()

返回 ()
子程序名返回值类型公开备 注
ToCallback整数型 
参数名类 型参考可空数组备 注
子程序子程序指针
是否有参数逻辑型
置入代码 ({ 62, 128, 125, 12, 1, 116, 17, 139, 69, 8, 131, 192, 4, 139, 200, 139, 0, 3, 193, 131, 192, 4, 235, 15, 139, 69, 8, 131, 192, 21, 139, 200, 139, 0, 3, 193, 131, 192, 4, 139, 229, 93, 194, 8, 0 })
返回 (0)
子程序名返回值类型公开备 注
Xcode整数型 内存指针读写操作
参数名类 型参考可空数组备 注
ptr整数型
dev整数型
val整数型
flags整数型
置入代码 ({ 139, 69, 20, 133, 192, 117, 13, 139, 77, 12, 139, 69, 8, 139, 4, 8, 93, 194, 16, 0, 131, 248, 1, 117, 14, 139, 77, 12, 139, 69, 8, 15, 183, 4, 8, 93, 194, 16, 0, 131, 248, 2, 117, 14, 139, 77, 12, 139, 69, 8, 15, 182, 4, 8, 93, 194, 16, 0, 131, 248, 4, 117, 18, 139, 69, 8, 139, 77, 12, 139, 85, 16, 137, 20, 8, 51, 192, 93, 194, 16, 0, 131, 248, 8, 117, 20, 139, 69, 8, 139, 77, 12, 102, 139, 85, 16, 102, 137, 20, 8, 51, 192, 93, 194, 16, 0, 131, 248, 16, 117, 19, 139, 69, 8, 139, 77, 12, 102, 139, 85, 16, 136, 20, 8, 51, 192, 93, 194, 16, 0 })
返回 (0)


i支持库列表   支持库注释   
spec特殊功能支持库



代码: ApiHook.rar (3.09 KB, 下载次数: 38)
结帖率:90% (27/30)
发表于 2021-5-28 17:29:06 | 显示全部楼层   河南省郑州市
11111111111111
回复 支持 反对

使用道具 举报

签到天数: 1 天

发表于 2016-4-16 19:38:28 | 显示全部楼层   广西壮族自治区桂林市
暂时不采纳
回复 支持 反对

使用道具 举报

结帖率:25% (1/4)
发表于 2016-4-10 21:31:30 | 显示全部楼层   广西壮族自治区南宁市
好伟大的帖子
回复 支持 反对

使用道具 举报

结帖率:100% (9/9)
发表于 2016-4-10 01:45:45 | 显示全部楼层   广东省深圳市
稳定性待验证,暂时不采纳
回复 支持 反对

使用道具 举报

签到天数: 17 天

发表于 2016-4-10 01:19:05 | 显示全部楼层   天津市天津市
本帖最后由 这不是坑爹么 于 2016-4-10 01:23 编辑

easy_hook.rar (9.91 KB, 下载次数: 31)
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表