pwn — ret2shellcode
2019-03-31 本文已影响202人
YeeZi_
Ret2shellcode:
按惯例检查保护,发现啥都没开
data:image/s3,"s3://crabby-images/f8673/f8673cae7a7b54359338efc58a6f6055829cf602" alt=""
用ida打开看main函数
data:image/s3,"s3://crabby-images/c3877/c3877a1749be68ed6ebcc98b44a02c19dd6657a5" alt=""
发现了gets和strncpy函数,将gets里的s的值存入了buf2
data:image/s3,"s3://crabby-images/301eb/301eb02b44705b3cdeb6e9506513492c2774ed3f" alt=""
题文中无system,无shellcode(据说是长成system(‘/bin/sh’)这样的东西),所以要自己写一个咯(写进栈里)
那就让它在脚本里生成一个shellcode(指令为:shellcode = asm(shellcraft.sh()))
得知偏移量为112
data:image/s3,"s3://crabby-images/5e2b2/5e2b2ebb3bb7b7e750ab9679e4a8dd75344662ed" alt=""
若生成的shellcode长度若不够112个,则用垃圾字符填充(指令:sh.sendline(shellcode.ljust(112,’a’) + bss段shellcode的地址))
还要检查bss段是否有权限写入shellcode,用vmmap
data:image/s3,"s3://crabby-images/e45ec/e45ec8a56d42549b61c625d60e1ef03ef2bf6b43" alt=""
发现buf2地址所在区间的权限是rwxp,可读可写
然后就可以安心地写exp了
data:image/s3,"s3://crabby-images/a06e7/a06e796173991eab5f02402b158db2d3f0bf43c0" alt=""