吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 2123|回复: 4
收起左侧

[其他转载] 攻防世界 int_overflow 超超超详细

[复制链接]
pushsafe 发表于 2020-11-19 07:29
pwn纯新手教程 如有错误的地方 希望各位大佬们指出.整数溢出int_overflow整数分为有符号(int)和无符号(unsigned int)两种类型
有符号数以最高位作为其符号位
即正整数最高位为 1,负数为 0
无符号数取值范围为非负数
常见各类型占用字节数如下:
类型 字节 取值范围
int 4 -2147483648~2147483647
short int 2 -32768~32767
long int 4 -2147483648~2147483647
unsigned int 4 0~4294967295
unsigned short int 2 0~65535
unsigned long int 4 0~4294967295也就是说,对于一个2字节的unsigned short int型变量
它的有效数据长度为两个字节
当它的数据长度超过两个字节
就溢出,溢出的部分则直接忽略
使用相关变量时,使用的数据仅为最后2个字节
因此就会出现65539等于3的情况
其他类型变量和数值与之类似。造成输出错误的原因在于把32 bit的int整数赋值给16bit的unsign short整数,赋值后只会取数值的后16bit值,高位截断,造成整数溢出0B = 二进制
bin(65535) =‘000b 1111 1111 1111 1111’
bin(65539) = ‘0001 0000 0000 0000 0011’
bin(3) = ‘0000 0000 0000 0000 0011’可以看到 bin(65539) 最终的值为0011 bin(3)也相同
RELRO:Partial RELRO
在mian函数中看到调用login函数其他的地方没问题

好像也没什么问题 但是出现了危险函数 check_passwd

首先 v3 设置了一个 unsigned _int8 v3 无符号 8位参数
v3 = 0 ~ 255
然后 v3 = strlen(s);
unsigned _init8 v3; 长度最大为8位 255
len是个unsigned int 8,而strlen()返回值是一个size_t类型的变量,它是无符号32bit的。

在第7行赋值的过程中,编译器会截断后者的末八位赋值给前者。8位的最大值是 255 ,所以如果passwd字符串长度
超过255就会导致溢出.看到上一层 read读取的时候 可以读取到0x199位数据 远远大于 255


所以存在整数型溢出漏洞.因为 溢出部分会将后八位赋值给前面 所以 在 255的基础上 加上 原本限制的4 - 8
在溢出后将255多余的部分赋值给v3 然后就能绕过if判断.259 - 264算取偏移值

首先看到 我们再绕过if 进入else以后 然后 将s的值赋值给dest然后进行赋值
可以看到 s 入栈以后 到 dest 系统stack默认分配了14个字节给dest
stack中给出的保存passwd的大小为0x14 :

再通过看汇编源码发现最后还有一个leave出栈 需要在多加4个字节从汇编代码中可以看到,想要覆盖到返回地址,先使用0x14 个数据覆盖stack拷贝的passed的内存区域,然后使用4字节数据覆盖ebp,再使用"cat flag"的地址覆盖返回地址,最后接上262剩余的数据即可。
(1)ESP:栈指针寄存器(extended stack pointer),其内存放着一个指针,该指针永远指向系统栈最上面一个栈帧的栈顶。(2)EBP:基址指针寄存器(extended base pointer),其内存放着一个指针,该指针永远指向系统栈最上面一个栈帧的底部。先用 0x14 覆盖掉 stack给dest 也就是 passwd分配的空间 然后 再用四个字节覆盖掉EBP 然后再将返回地址 用 catflag地址覆盖掉 最后将262个剩余的数据接上即可.取用 262个字节 第一部分 0x14 stack给passwd分配的空间第二部分 0x4 leave分配的4个字节 第三部分 cat flag 占用的 十个字节第四部分 262减去占用的 剩下的部分/payload = ‘A’ * 0x14 + ‘a’ * 0x4 + p32(cat_flag_address) + ‘B’ * 234
p32/64 = 对数据进行打包 转换为2进制数据payload 这地方 ‘B’ * 234 一定不能 写成 0x234

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

wanshiz 发表于 2020-11-19 13:41
留空收藏,谢谢楼主分享。
heidiansama 发表于 2020-11-20 11:06
yntcxlong 发表于 2021-11-25 22:51
hiodis 发表于 2022-1-3 06:18
不懂,感谢分享
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2025-1-13 07:32

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

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