开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 3688|回复: 17
收起左侧

[已解决] 内存调call后 取eax返回值

 关闭 [复制链接]
结帖率:65% (11/17)
发表于 2020-5-22 14:08:39 | 显示全部楼层 |阅读模式   浙江省温州市
50精币
本帖最后由 亲爱的小层 于 2020-5-23 00:48 编辑

如何取eax

如何取eax

代码如上,就是想取回call的返回值,然后传回调用方.   百d 精益都搜过,有些人的诉求跟我一样,也有一些跟帖,但好像没有实际解决。
希望有相关经验的前辈,贴个代码或者传个源码让我参考下。      dll注入方式  

最佳答案

查看完整内容

整数型 eax ret=取变量数据地址(eax) 汇编.mov_eax_dword_ptr(十到十六( ret)) //有可能反了,没用过这个汇编模块 原指令就是 mov [ret],eax 意思就是把eax的值存到变量eax里面去

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

签到天数: 2 天

发表于 2020-5-22 14:08:40 | 显示全部楼层   广东省韶关市
整数型  eax
ret=取变量数据地址(eax)
汇编.mov_eax_dword_ptr(十到十六( ret)) //有可能反了,没用过这个汇编模块  原指令就是  mov [ret],eax
意思就是把eax的值存到变量eax里面去
回复

使用道具 举报

结帖率:100% (56/56)

签到天数: 10 天

发表于 2020-5-22 14:31:59 | 显示全部楼层   山西省太原市
子程序传入一个传地的参数来接受返回值,汇编.call_ebx()后,执行 mov [ebp+4],eax。
回复

使用道具 举报

结帖率:100% (6/6)
发表于 2020-5-22 14:42:11 | 显示全部楼层   上海市上海市
要取寄存器的值,得用超级hook吧
回复

使用道具 举报

结帖率:97% (67/69)

签到天数: 9 天

发表于 2020-5-22 14:53:48 | 显示全部楼层   浙江省台州市
置入代码({ 93, 195 })
意思是返回eax的值,你在把返回(eax)改成返回(0)就ok
回复

使用道具 举报

结帖率:100% (4/4)

签到天数: 7 天

发表于 2020-5-22 15:35:31 | 显示全部楼层   福建省龙岩市
上面说的都是内联汇编的方法,远程汇编的话就申请一块内存,call完后把EAX赋值到你申请的那块内存,然后读取你申请的内存就OK了
回复

使用道具 举报

头像被屏蔽
结帖率:79% (15/19)
发表于 2020-5-22 19:58:03 | 显示全部楼层   贵州省黔东南苗族侗族自治州
得先个申请空白地址 然后吧 ebx 赋值 到申请的地址里面 读内存 读出来就行了    Mov_Ptr_EBX (申请的内存地址)  返回值 = 读整数型 (申请的内存地址)
回复

使用道具 举报

结帖率:65% (11/17)
 楼主| 发表于 2020-5-22 23:54:09 | 显示全部楼层   浙江省温州市
晴雯晴雯 发表于 2020-5-22 14:31
子程序传入一个传地的参数来接受返回值,汇编.call_ebx()后,执行 mov [ebp+4],eax。

QQ图片20200522234915.png

mov [ebp+4],eax   翻译成机器码,放到call后面,大佬是不是这个意思?  加了这段调用就崩,是我上层参数设置错了 还是  [ebp+8] 才是 上层调用call的第1个参数(即图片里的返回值)  ?
回复

使用道具 举报

结帖率:100% (56/56)

签到天数: 10 天

发表于 2020-5-23 08:21:15 | 显示全部楼层   山西省太原市
置入代码({139,77,8,137,1})

mov ecx,[ebp+0x08]
mov [ecx], eax

评分

参与人数 1精币 +1 收起 理由
meesst + 1 YYDS~!

查看全部评分

回复

使用道具 举报

发表于 2020-5-23 21:20:54 | 显示全部楼层   河北省秦皇岛市
在红框这个地方  保护一下EAX的值到内存(不能使用寄存器偏移寻址,因为后面寄存器值会变化 ),然后在POPAD后面把保护的值还原到EAX里面去。因为POPAD会把出栈一堆寄存器的值
回复

使用道具 举报

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

本版积分规则 致发广告者

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

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

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