开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 2538|回复: 4
收起左侧

[已解决] 无名侠写的HOOK例程。有一步看不明白。求指点下~

 关闭 [复制链接]
结帖率:99% (269/273)
发表于 2015-1-4 19:09:27 | 显示全部楼层 |阅读模式   广东省广州市
5精币
本帖最后由 E族x天天软件 于 2015-1-4 19:17 编辑

http://bbs.125.la/thread-13766104-1-1.html  
这个是无名侠写的HOOK  例程,写的非常不错。但是有一步有点不理解啊。附件我也一并上传了。
如图:
1:就是调回 原函数时为什么要   在原来的地址  +5啊 。加了5就回不到原函数了吧。
2:jmpCode = { 233 }  ' jmp xxx 相对地址             这个jmpcode是怎么来的啊?
谁能解释下啊。。@无名侠


易语言的那些事.rar

241.98 KB, 下载次数: 6

hook3.jpg

最佳答案

查看完整内容

用OD看看就知道了。 我们HOOK了函数头,Windows DLL的导出函数开头基本上mov edi,edi 刚好5字节,可以存下一个JMP指令。 所以我们跳回原函数的时候 要+5,要不然又相当于调用自己了,然后又跳到中继函数,然后无限循环。

求助知识:请将问题描述清楚,最好把你有问题的源码打包上传上来,这样更方便大家帮助你。
友情提醒:本版被采纳的主题可在 申请荣誉值 帖子申请荣誉值,获得 3点 荣誉值,荣誉值可兑换荣誉会员、终身vip用户组。

结帖率:40% (31/78)
发表于 2015-1-4 19:09:28 | 显示全部楼层   山西省阳泉市
用OD看看就知道了。
我们HOOK了函数头,Windows DLL的导出函数开头基本上mov edi,edi 刚好5字节,可以存下一个JMP指令。
所以我们跳回原函数的时候 要+5,要不然又相当于调用自己了,然后又跳到中继函数,然后无限循环。

评分

参与人数 1荣誉 +3 收起 理由
笨潴 + 3 热心帮助他人,荣誉+3,希望继续努力(*^__^*) 嘻嘻!

查看全部评分

回复

使用道具 举报

结帖率:40% (2/5)
发表于 2015-1-4 19:33:20 | 显示全部楼层   北京市北京市
我也不懂啊
回复

使用道具 举报

结帖率:40% (31/78)
发表于 2015-1-4 19:52:48 | 显示全部楼层   湖南省常德市
jmpCode
是 jmp 相对地址的机器码。
{233} 16进制是0xe9
后面跟4字节操作数,就是相当跳转地址.
jmp 绝对地址好像是大于5字节的
而函数头也只有5字节(mov edi,edi) 专门给我们安装这些用的。
具体指令机器码去方法Intel官方的手册把
回复

使用道具 举报

结帖率:99% (269/273)
 楼主| 发表于 2015-1-4 20:17:45 | 显示全部楼层   广东省广州市
无名侠 发表于 2015-1-4 19:52
jmpCode
是 jmp 相对地址的机器码。
{233} 16进制是0xe9

多谢,你分享的代码非常不错
回复

使用道具 举报

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

本版积分规则 致发广告者

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

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

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