开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

楼主: dnxl
收起左侧

[易语言模块源码] 更新TR模块,子类化 主线程CALL 内存加载...X32/X64同步支持

  [复制链接]
发表于 2025-2-20 23:01:01 | 显示全部楼层   河南省商丘市
感谢大佬分享
回复 支持 反对

使用道具 举报

签到天数: 2 天

发表于 2025-2-16 02:18:54 | 显示全部楼层   河南省安阳市
感谢分享
回复 支持 反对

使用道具 举报

结帖率:60% (3/5)

签到天数: 2 天

 楼主| 发表于 2025-2-15 19:12:57 | 显示全部楼层   广西壮族自治区柳州市
haipa123 发表于 2025-2-15 13:47
可以整个修改内存属性的函数吗,有些静态地址无法写入

模块内部所有写内存函数,都是先改内存再写的,不存在属性不对无法写入问题
回复 支持 1 反对 0

使用道具 举报

签到天数: 2 天

发表于 2025-2-15 13:47:27 | 显示全部楼层   福建省龙岩市
可以整个修改内存属性的函数吗,有些静态地址无法写入
回复 支持 反对

使用道具 举报

发表于 2025-2-14 22:07:21 | 显示全部楼层   广东省惠州市
dnxl 发表于 2025-2-13 15:35
已更新,不过不是所有DLL都支持内存加载

非常感谢,太好用了。
回复 支持 反对

使用道具 举报

发表于 2025-2-14 16:04:45 | 显示全部楼层   江苏省无锡市
到楼下下载新的。
回复 支持 反对

使用道具 举报

结帖率:60% (3/5)

签到天数: 2 天

 楼主| 发表于 2025-2-14 15:42:59 | 显示全部楼层   广西壮族自治区柳州市
青峰随处飘 发表于 2025-2-14 12:58
Target_Memload_dll里有一个语句我不是很懂,展开PE文件填充文件重定位后有一句
写到内存(1018304599, P ...

也就是给内存加载的DLL做个标志,后面用来判断内存DLL是否已存在
回复 支持 反对

使用道具 举报

发表于 2025-2-14 13:20:41 | 显示全部楼层   河北省衡水市
本帖最后由 青峰随处飘 于 2025-2-14 13:21 编辑
dnxl 发表于 2025-2-14 02:11
填充导入表:
PE文件要执行,它要依赖很多系统API函数,比如kernel32.dll,user32.dll中的函数等等(有可 ...

昨天研究一天没发现错误,今天看了半天原来是我封装的写入内存的函数,里面实现参数没填好一直写入固定的数值已经解决了 167d305e2f69a9c0916bf097495ea28e.png 返回值也正确了

回复 支持 反对

使用道具 举报

发表于 2025-2-14 12:58:14 | 显示全部楼层   河北省衡水市
dnxl 发表于 2025-2-14 02:11
填充导入表:
PE文件要执行,它要依赖很多系统API函数,比如kernel32.dll,user32.dll中的函数等等(有可 ...

Target_Memload_dll里有一个语句我不是很懂,展开PE文件填充文件重定位后有一句
写到内存(1018304599, PPE, 4)
请问这条语句的具体作用是什么?
回复 支持 反对

使用道具 举报

结帖率:60% (3/5)

签到天数: 2 天

 楼主| 发表于 2025-2-14 02:11:59 | 显示全部楼层   广西壮族自治区柳州市
青峰随处飘 发表于 2025-2-13 20:47
大佬出个教程讲讲 填充导入表 jz重定位 吧 我按着你源码在c#写 远程call 是可以顺利实现的 但是我写目标_ ...

填充导入表:
PE文件要执行,它要依赖很多系统API函数,比如kernel32.dll,user32.dll中的函数等等(有可能还会依赖第三方DLL函数)
导入表就存储PE文件所依赖的函数在当前进程中的地址,如果依赖的DLL还未在当前进程加载还要先加载它依赖的DLL。
不同系统,系统API函数在内存中的地址是不一样的,为了程序能兼容不同系统运行,在它加载到内存后,首先要对导入表进行填充,
先读取表中它要调用的函数名或序号,然后取到函数在当前进程中的地址写入表中指定位置,它才能正确的CALL到函数。

jz重定位:
PE文件都有一个默认加载地址,它的功能CALL有些代码是直接寻址的,都是以默认加载地址为基准,编译时这些数值都写死在里面
但是在真正运行时它不一定能加载到默认地址上,所以在加载到内存运行前要先判断它加载的地址是不是默认地址,如果不是必须要把编译那些写死的数值改掉,
重定位表就记录着哪个地方的数值需要改动,改成什么得看真实加载地址和默认地址的差值。不然,运行时代码会跳错地地方或者CALL地方肯定是会崩的

内存加载主要就是改这两个表,怎么找到这两个地方,怎么改网上教程也不少了,讲的也详细

而我用的方法是按远程进程的地址在本地修复后写入远程进程运行,其原理都是一样的




回复 支持 反对

使用道具 举报

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

本版积分规则 致发广告者

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

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

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