190404 逆向-利用溢出修改TLS的re题

本文介绍了通过逆向工程分析一个存在溢出的程序,发现可以利用错误指令附近的异常处理结构来修改TLS。通过cyclic工具生成payload并触发异常,确定了溢出点。由于存在check函数且其地址不可见,选择直接跳转到'OK'标签。最后,分析发现溢出内存涉及静态TLS,进一步验证了这一结论。
摘要由CSDN通过智能技术生成

偶然在52上看到 这个帖子
顺手打开看了一下
在这里插入图片描述

主函数这里有个错误指令,附近没有跳转所以大概不是花
往上翻一下
在这里插入图片描述
标准的try语句,新增了一个异常处理结构
在这里插入图片描述

可以看到handler指向了401269+1的地方,而401269正好就是错误指令地址
也就是说相当于一个花了
在这里插入图片描述

修正一下变成这个样子

直接输出RROR!然后退出
就全完了233

注意到输入的buff在data段,以及scanf是%s来的,所以存在溢出
在这里插入图片描述
下面的这一堆鬼东西有名字的就没几个,交叉引用还都指向start函数

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值