开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 18198|回复: 60
打印 上一主题 下一主题
收起左侧

[易语言纯源码] 堆内存释放bug修复2.0 重写兼容数据执行保护

[复制链接]
结帖率:33% (2/6)
跳转到指定楼层
楼主
发表于 2019-8-11 19:07:03 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式   广东省广州市
分享源码
界面截图: -
是否带模块: -
备注说明: -
之前发过一个堆内存释放无效指针导致崩溃的帖子
原帖=  https://125.confly.eu.org/forum.php?mod=viewthread&tid=14327228&extra=


这个bug   win的dll也是存在的    貌似17年也有人发过帖子  利用这个bug可以进行页覆盖执行shellcode  前不久看到的攻击漏洞

但是这个bug正常使用中触发几率非常非常小,可能被window忽略了

但是这些bug一旦触发却会影响我们的程序,比如一些莫名其妙的崩溃,也许时它造成的。

距离发那个帖子也有很长时间了,不知道新版易语言有没有添加检测了 或者 微软有没有修复了

但是用低版本的还是有的,比如我


由于原帖的修复补丁采用的时shellcode方式,在系统开启了数据执行保护就直接崩溃了


因为一直懒得写,就没有再发,因为这个修复确实有点简单了  就hook一下。

好吧,多人反馈崩溃,今天就重写了个,编译性的静态hook,不再使用内存执行,兼容数据执行保护的

其实也是很简单的,虽然我这里只写了只能安装MOV edi,edi  栈帧头   开头的,

(静态无冲突hook的实现): 原理是很简单的,无非就是利用编译所生成的程序内存,因为在这块内存执行EDP是不会冲突的,完全可以预留一块内存并直接修改使用,但是要实现高速执行需要考虑到对齐的方式,这里就不再详细说了。

当然,我这里写的hook仅针对于这个堆内存释放api了  所以里面是没有静态且无冲突hook安装的动态实现的。这里面是静态实现了。



更新内容:
               1.不再使用内存执行
               2.不再使用HeapSize进行指针检测(因为HeapSize api也有bug的 检测不对劲的指针也会崩溃,不知道是特权指针还是什么指针的问题。。反正我没弄明白,指针是正常的就是崩了,可能是缺少了点什么东西。)
               3.使用自定义指针检测(虽然无法保证这个指针是堆内存的指针,但是问题不大),




测试动图



修复堆释放2.0.rar (338.15 KB, 下载次数: 467)

评分

参与人数 6好评 +6 精币 +14 收起 理由
logite + 1 + 2 感谢分享,很给力!~
易语言资源网 + 1 + 5 支持开源~!感谢分享
阳光男人 + 1 + 1 感谢发布原创作品,精易因你更精彩!
呵呵仙 + 1 + 3 感谢发布原创作品,精易因你更精彩!
1185384801 + 1 + 3 新技能已get√
wscpf1919 + 1 请问楼主 这个能否用于增加多线程的稳定性

查看全部评分


本帖被以下淘专辑推荐:

结帖率:33% (2/6)
沙发
 楼主| 发表于 2019-8-11 19:34:57 | 只看该作者   广东省广州市
@wscpf1919  多线程稳定性因素有很多的。比如一条线程使用内存过于离谱也会被内存管理杀,因为用的进程默认堆,这种情况就需要让线程拥有自己的堆了,虽然我早写好了。。。这个修复仅是修复内存重释放导致崩溃的bug,适合多线程的,如果线程所调用的命令有重释放bug的 ,也能提升一定的稳定性的。
回复 支持 反对

使用道具 举报

结帖率:100% (4/4)
板凳
发表于 2019-8-11 21:07:44 | 只看该作者   河北省邯郸市
下载看看
回复 支持 反对

使用道具 举报

签到天数: 1 天

地板
发表于 2019-8-11 21:09:46 | 只看该作者   安徽省安庆市
66666的源码!
回复 支持 反对

使用道具 举报

结帖率:80% (8/10)
地下
发表于 2019-8-11 21:21:01 | 只看该作者   广东省广州市
回复 支持 反对

使用道具 举报

结帖率:100% (26/26)

签到天数: 7 天

6
发表于 2019-8-11 23:18:39 | 只看该作者   江苏省南通市
求挑战分享 文本按分隔符分割成文本数组的快速方法 看到易语言官方论坛那边说 一千万行数据按分隔符分割到文本数组只需260毫秒左右?这么快?很好奇!!!http://bbs.eyuyan.com/read.php?tid=408061&page=6
回复 支持 反对

使用道具 举报

结帖率:33% (2/6)
7
 楼主| 发表于 2019-8-12 01:33:18 | 只看该作者   广东省广州市
hellohexiang 发表于 2019-8-11 23:18
求挑战分享 文本按分隔符分割成文本数组的快速方法 看到易语言官方论坛那边说 一千万行数据按分隔符分割到 ...

这个啊  我发现这个重释放会导致崩溃的时候就是在写快速分割的。  不过当时写了有个bug就放着了  实用性也不太大   分割了也只能读取,不能其他操作。。。后面弄链表数组了,快速又能对成员操作还能秒释放。听你一说翻出来修复bug,汇编代码用位运算实现的,看了半天,我都不知道我TM当初写的是啥。。。  不过修复好了

1000万行的话,一行5个字节这个速度



源码给你了。 快速分割.e (11.26 KB, 下载次数: 17)

点评

自动释放也能实现,变量的销毁有专门的代码段,可以讲第一个成员的指针放到链表,再hook释放api,检测链表,通过返回地址检测释放数组特征代码块,再给它构造个空数组。。   广东省广州市  发表于 2019-8-12 16:29
不知道还有没bug,用换行符分割的话貌似是很正常的。。。。   广东省广州市  发表于 2019-8-12 01:43

评分

参与人数 1好评 +1 精币 +3 收起 理由
hellohexiang + 1 + 3 很给力 如果能自动释放就完美了

查看全部评分

回复 支持 反对

使用道具 举报

结帖率:100% (8/8)

签到天数: 1 天

8
发表于 2019-8-12 23:36:38 | 只看该作者   湖南省长沙市
感谢分享!!!!!!!
回复 支持 反对

使用道具 举报

结帖率:40% (4/10)
9
发表于 2019-8-13 08:56:01 高大上手机用户 | 只看该作者   四川省成都市
感谢楼主666666
回复 支持 反对

使用道具 举报

结帖率:100% (6/6)
10
发表于 2019-8-13 13:04:41 | 只看该作者   内蒙古自治区赤峰市
修复堆释放?
回复 支持 反对

使用道具 举报

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

本版积分规则 致发广告者

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

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

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