题目信息
nc pwn2.jarvisoj.com 9882
64位elf,只开了NX
data:image/s3,"s3://crabby-images/6ce4c/6ce4c8387e8553470168dc30e391f805de85cdaf" alt="img"
img
静态分析
IDA F5,明显溢出
data:image/s3,"s3://crabby-images/daff8/daff8e7d0f1c9efc8c665aec31736a5a764493d0" alt="img"
img
data:image/s3,"s3://crabby-images/b872c/b872c69f2bf1a9c5533bbe571ed8eb4a76bfe428" alt="img"
img
其他地方和level2没什么区别,只是64位和32位栈的区别
在32位程序运行中,函数参数直接压入栈中
- 调用函数时栈的结构为:调用函数地址->函数的返回地址->参数n->参数n-1->···->参数1
在64位程序运行中,参数传递需要寄存器
64位参数传递约定:前六个参数按顺序存储在寄存器rdi, rsi, rdx, rcx, r8, r9中
参数超过六个时,从第七个开始压入栈中
exploit
所以我们将”/bin/sh”作为system函数参数的话需要一个pop rdi的gadget,直接使用ROPGadget查找
data:image/s3,"s3://crabby-images/43c8f/43c8f0656d71dee7164445e61d801366e4ce5176" alt="img"
img
之后构造exp即可
构造exp
1 | from pwn import * |
getflag
data:image/s3,"s3://crabby-images/3ebb1/3ebb1333b1018bc9c1f516a185199c192cc62e24" alt="img"
img