开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 6335|回复: 24
收起左侧

[已解决] 关于读内存 模块地址+偏移的写法

 关闭 [复制链接]
结帖率:50% (6/12)
发表于 2022-1-16 16:50:20 | 显示全部楼层 |阅读模式   陕西省西安市
14精币

1

1

上图为ce结果  下面为易语言代码 使用了精益模块 。但是读内存的值是0。验证过模块的基址是正确的。怀疑读内存过程出问题。求解。
  
窗口程序集名保 留  保 留备 注
窗口程序集_启动窗口   
子程序名返回值类型公开备 注
__启动窗口_创建完毕  
变量名类 型静态数组备 注
模块类_模块枚举 
PID整数型 
基址整数型 
PID = 18220
基址 = 进制_十六到十 (模块.模块名取句柄 (PID, “python27.dll”)) + 进制_十六到十 (“00585398”)
内存.读整数 (PID, 基址 + 进制_十六到十 (“C0”)进制_十六到十 (“70”)进制_十六到十 (“90”)进制_十六到十 (“148”)进制_十六到十 (“780”))
调试输出 (内存.读整数 (PID, 基址 + 进制_十六到十 (“C0”)进制_十六到十 (“70”)进制_十六到十 (“90”)进制_十六到十 (“148”)进制_十六到十 (“780”)))
调试输出 (内存.读代码_整数 (PID, 模块.模块名取句柄 (PID, “python27.dll”)“00585398+c0+70+90+148+780”))


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



最佳答案

查看完整内容

超过0X7FFFFFFF必然是64位指针, CE上面的表达式为 [[[[+c0]+70]+90]+148]+780 想要读出来这个第一步就是取得模块加载首地,目标是个64位进程,存地址的变量必须是长整数,内存读写模块必须支持64位进程 临时变量 = 取模块句柄(pid,"python27.dll") 临时变量 = 内存读整数(pid,临时变量+进制_十六到十("585398")) 临时变量 = 内存读整数(pid,临时变量+进制_十六到十("c0")) 临时变量 = 内存读整数(pid,临时变量+进制_十六到十("70") ...

回答提醒:如果本帖被关闭无法回复,您有更好的答案帮助楼主解决,请发表至 源码区 可获得加分喔。
友情提醒:本版被采纳的主题可在 申请荣誉值 页面申请荣誉值,获得 1点 荣誉值,荣誉值可兑换荣誉会员、终身vip用户组。
快捷通道:申请荣誉值
结帖率:80% (4/5)

签到天数: 11 天

发表于 2022-1-16 16:50:21 | 显示全部楼层   广西壮族自治区柳州市
超过0X7FFFFFFF必然是64位指针,
CE上面的表达式为
[[[[[python27.dll+585398]+c0]+70]+90]+148]+780
想要读出来这个第一步就是取得模块加载首地,目标是个64位进程,存地址的变量必须是长整数,内存读写模块必须支持64位进程
临时变量 = 取模块句柄(pid,"python27.dll")
临时变量 = 内存读整数(pid,临时变量+进制_十六到十("585398"))
临时变量 = 内存读整数(pid,临时变量+进制_十六到十("c0"))
临时变量 = 内存读整数(pid,临时变量+进制_十六到十("70"))
临时变量 = 内存读整数(pid,临时变量+进制_十六到十("90))
临时变量 = 内存读整数(pid,临时变量+进制_十六到十("148"))
结果 = 内存读整数(pid,临时变量+进制_十六到十("780"))
回复

使用道具 举报

结帖率:98% (54/55)

签到天数: 11 天

发表于 2022-1-16 17:21:44 | 显示全部楼层   陕西省西安市
怎么给你说呢,你得读一层加一个偏移  不是这样相加的

补充内容 (2022-1-16 17:22):
还有 很明显这是X64的  你用精益的内存读写是X86不行的。
回复

使用道具 举报

结帖率:91% (29/32)

签到天数: 10 天

发表于 2022-1-16 17:32:46 | 显示全部楼层   上海市上海市
ManNanIsMe 发表于 2022-1-16 17:21
怎么给你说呢,你得读一层加一个偏移  不是这样相加的

补充内容 (2022-1-16 17:22):

怎么一眼看出来是x64的呀
回复

使用道具 举报

结帖率:50% (6/12)
 楼主| 发表于 2022-1-16 18:03:35 | 显示全部楼层   陕西省西安市
ManNanIsMe 发表于 2022-1-16 17:21
怎么给你说呢,你得读一层加一个偏移  不是这样相加的

补充内容 (2022-1-16 17:22):

麻烦给下代码。
还有就是你怎么确定是64的?我读其他固定位置的内存是可以的。所此条不成立。

点评

看地址, 地址超过4个字节了, 只能是x64   广西壮族自治区崇左市  发表于 2022-1-16 18:21
回复

使用道具 举报

结帖率:50% (6/12)
 楼主| 发表于 2022-1-16 18:38:22 | 显示全部楼层   陕西省西安市
duanyiemo3 发表于 2022-1-16 18:03
麻烦给下代码。
还有就是你怎么确定是64的?我读其他固定位置的内存是可以的。所此条不成立。 ...

我用读内存 读了其他地址 读出来了 是正确的~
现在就是这个多级的问题不好处理、
回复

使用道具 举报

结帖率:50% (6/12)
 楼主| 发表于 2022-1-16 18:53:00 | 显示全部楼层   陕西省西安市
回复

使用道具 举报

结帖率:100% (18/18)

签到天数: 11 天

发表于 2022-1-16 18:53:50 | 显示全部楼层   福建省泉州市
模块名取句柄
你取到的只是模块对应的句柄,而不是从模块里读出的基址
你要先从模块里读出基址   再加基址偏移     才是实际的基址
然后再加后面的偏移一级一级读取
基址都不对,读出来肯定不对了
回复

使用道具 举报

结帖率:50% (6/12)
 楼主| 发表于 2022-1-16 19:14:05 | 显示全部楼层   陕西省西安市
铃儿响叮当 发表于 2022-1-16 18:53
模块名取句柄
你取到的只是模块对应的句柄,而不是从模块里读出的基址
你要先从模块里读出基址   再加基址 ...

给个例子啊  就是不会啊 有例子看一下就明白了
回复

使用道具 举报

结帖率:100% (5/5)
发表于 2022-1-16 19:35:50 | 显示全部楼层   广西壮族自治区南宁市
duanyiemo3 发表于 2022-1-16 18:53
@剩下我de孩子气 @七彩色工作室

这么高级的别艾特我啊,我不会啊
回复

使用道具 举报

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

本版积分规则 致发广告者

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

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

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