开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

楼主: 树上的鱼儿
收起左侧

[易语言纯源码] 浅谈64位进程远程hook技术及64模块导出表的一些变化,附源码

    [复制链接]

结帖率:100% (42/42)
发表于 2021-2-15 21:20:30 | 显示全部楼层   广东省广州市
准确的说是八九年前
回复 支持 反对

使用道具 举报

签到天数: 3 天

 楼主| 发表于 2021-2-15 10:44:56 | 显示全部楼层   浙江省绍兴市
呵呵呵666 发表于 2021-2-15 05:10
请问大佬是不是就是hook地址上的那条指令不足6字节长度就要加上下一条指令的长度(如果不够就还要加上下 ...

对,一条或多条完整的指令必须大于等于6字节,多长参数就设置多长
回复 支持 反对

使用道具 举报

结帖率:100% (3/3)
发表于 2021-2-15 05:10:28 | 显示全部楼层   四川省成都市
树上的鱼儿 发表于 2021-2-15 00:00
差不多就是这个意思,HOOK需要把HOOK位置的指令改成JMP跳转到目标进程申请空间内,而这条指令JMP[RIP]占用 ...

请问大佬是不是就是hook地址上的那条指令不足6字节长度就要加上下一条指令的长度(如果不够就还要加上下下面一条的直到加够)如果足够6字节就直接填那条指令的长度
回复 支持 反对

使用道具 举报

签到天数: 3 天

 楼主| 发表于 2021-2-15 00:00:17 | 显示全部楼层   浙江省绍兴市
本帖最后由 树上的鱼儿 于 2021-2-15 00:04 编辑
呵呵呵666 发表于 2021-2-14 23:37
长度是指的要替换成jmp的那条指令的长度吗

差不多就是这个意思,HOOK需要把HOOK位置的指令改成JMP跳转到目标进程申请空间内,而这条指令JMP[RIP]占用6字节,所以HOOK长度不能小于6字节,最好进调试器查看HOOK位置处完整代码是否够6字节,不够就往下加一条指令,在不够在加一条,依次类推,如果3条指令正好6字节那么HOOK长度就是6,假如hook位置指令占用7字节,那么长度就是7,程序会改写此处代码为JMP跳转6字节,多余的1字节源码内会自动处理,自动填充空指令也就是NOP,这样才不会打乱原代码指令,如果提供的HOOK长度乱填,会导致目标程序经过时崩溃,具体可以查看帖子内那张HOOK位置的贴图
回复 支持 反对

使用道具 举报

结帖率:100% (3/3)
发表于 2021-2-14 23:37:34 | 显示全部楼层   四川省成都市
树上的鱼儿 发表于 2021-2-14 20:57
朋友我只能说对于HOOK的情况,因为面对的是机器码,所以要懂一点基础的汇编知识方能如掌握神器无坚不摧, ...

长度是指的要替换成jmp的那条指令的长度吗
回复 支持 反对

使用道具 举报

结帖率:64% (28/44)
发表于 2021-2-14 23:05:45 | 显示全部楼层   安徽省宣城市
新技能已get√
回复 支持 反对

使用道具 举报

结帖率:100% (5/5)
发表于 2021-2-14 22:26:52 | 显示全部楼层   四川省成都市
厉害 读完受益匪浅!
回复 支持 反对

使用道具 举报

签到天数: 3 天

 楼主| 发表于 2021-2-14 20:57:41 | 显示全部楼层   浙江省绍兴市
创世之神 发表于 2021-2-14 20:34
话说,大佬~ Hook长度要怎么算呀~ 系统API的~ 不会用OD(整半天HOOK,才发现,要注入的程序是64位的{:7_4 ...

朋友我只能说对于HOOK的情况,因为面对的是机器码,所以要懂一点基础的汇编知识方能如掌握神器无坚不摧,所以能熟练的使用调试器是必须的,这样才能理解HOOK的意义和执行的流程,关于HOOK长度这要看你HOOK的目的,比如32位AIP hook一般在函数头部即可且一般为5字节都可以,因为32位函数头一般为push等占用1字节汇编指令,而64位则情况不定,一般头部位抬栈指令等,所以要定义HOOK长度必须经过调试器的打开,看清楚位置的汇编指令,长度根据HOOK处汇编长度来定义,看HOOK功能最小支持多长,假如是6字节那么在HOOK位置的指令要够6字节,假如一条指令不够就增加一条指令直至6字节,假如超过6字节,也无关系,参数中定义HOOK长度,总而言之,HOOK长度是由每条完整指令构成的,我不知道我这样解释你能不能理解,如果不能理解的话请朋友暂时放弃关于这项内容的研究,如若有兴趣可增强自身汇编能力,到时自然一通百通,我只能说,对于我这个开源帖中64位远程HOOK中的使用不适合无汇编基础的朋友,因为这个封装太自由了,我这个封装不是面对基础用户的,因为在封装之初我不想为了适应基础用户来阉割这个功能,自由性才能展现无线可能,才能应对各种情况与要求

评分

参与人数 1好评 +1 精币 +2 收起 理由
元老 + 1 + 2 原来如此,谢谢大佬

查看全部评分

回复 支持 反对

使用道具 举报

结帖率:78% (71/91)

签到天数: 1 天

发表于 2021-2-14 20:34:22 | 显示全部楼层   河北省廊坊市
树上的鱼儿 发表于 2021-2-14 11:09
跟什么系统没有关系,模块中的列子只给了写法,用的时候要根据hook位置的情况来,长度不能定义错,要实现 ...

话说,大佬~ Hook长度要怎么算呀~ 系统API的~ 不会用OD(整半天HOOK,才发现,要注入的程序是64位的
回复 支持 反对

使用道具 举报

结帖率:75% (3/4)

签到天数: 2 天

发表于 2021-2-14 13:39:10 | 显示全部楼层   河北省石家庄市
高大上啊
回复 支持 反对

使用道具 举报

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

本版积分规则 致发广告者

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

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

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