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

[Pwn之路]根据所给库,获得远程同环境——使用patchelf的正确姿势

原文:https://www.freebuf.com/sectool/366854.html
存自己这里方便看。

0x00 前言

如何修改本地pwn文件和题目所给环境一致,从而进行调试,这是从学习堆开始就遇到的心头之患。从那以后,直到今天参加完mini LCTF,为了复现一道题目才把这个问题解决掉。网上的博客,参差不齐,由于本人不才,导致都不起作用。故在某学长在校内论坛之中找到正确方法,从而解决了这一心头之患。

并且这里面有一些小问题,也希望请教一下大家。问题我会用Q来表示,欢迎捕捉!

0x01 安装所需软件

glibc-all-in-one

最快的方式是:

git clone https://github.com/matrix1001/glibc-all-in-one.git 
cd glibc-all-in-one 
chmod a+x build download extract

如果不行(我就是不行…),进入下方链接。

ps:后来发现是ipv6掉认证了

image

点击download下载,手动解压

然后运行sudo python update_list(如果遇到报错请检查网络问题,我在那里卡了比较久,注意要用direct连接。这里不明白什么意思的话不用管我),接着cat list得到包名。

image

patchelf

我是archlinux,yay patchelf就可以安装好,所以在这里没有遇到什么问题。其他子系统,可以自行搜索,网上的教程很详细,大家可以自行解决。

0x02 确定patch什么库

修改:新增快方法

在有题目所给libc.so.6的目录下直接输入strings libc.so.6 |grep Ubuntu 即可。
image

1.确定偏移用于搜索

使用ROPgadget

这里的思路我的比较简单,ROPgadget用来查str_bin_sh的地址。

ROPgadget --binary libc.so.6 --string '/bin/sh'

得到

image
Q1:那么有没有办法用ROP来查printf,system之类的地址呢?我暂时没查到相关命令,如果有的话会很简单,不需要接下来的步骤。

使用pwntools

from pwn import *p = process('./pwn')
libc = ELF('./libc.so.6')
elf = ELF('./pwn')system = libc.sym['system']#这里的system可以替换成别的函数,用于搜索偏移
print(hex(system))
if args.G:gdb.attach(p)p.interactive()

运行。
image

于是我们得知,system的偏移是0x50d60

3.搜索库

推荐两个网站一起用,找不到的话换另一个,一定要多搜索几个偏移确保没错。其实也可以使用libc-database,不过这个不是这篇文章的重点。

https://libc.rip/
https://libc.blukat.me/

image
得到库名。

0x03 下载库

运行cat list找到2.35-0ubuntu3.1_amd64。
image
cd到年装的glibcallinone的文件夹下。

输入./download 2.35-0ubuntu3.1_amd64即可。
但是我一开始不太一样,我遇到了问题如下:

~/ctf/tools/glibcallinone » ./download 2.35-0ubuntu3.1_amd64

Getting 2.35-0ubuntu3.1_amd64 -> Location:
https://mirror.tuna.tsinghua.edu.cn/ubuntu/pool/main/g/glibc/libc6_2.35-0ubuntu3.1_amd64.deb
-> Downloading libc binary package Failed to download package from https://mirror.tuna.tsinghua.edu.cn/ubuntu/pool/main/g/glibc/libc6_2.35-0ubuntu3.1_amd64.deb

于是只能自己登入,然后解压。

后来发现是没安装wget且校园网ipv6掉认证,重新登陆一下后成功。
image

0x04 patch!!

找到你的ld和libc.so.6文件。
image
找到他们的目录,然后在pwn题目文件目录下运行以下两条命令:

patchelf --set-interpreter 你的文件目录/ld-linux-x86-64.so.2 ./pwnpatchelf --add-needed 你的文件目录/libc.so.6 ./pwnpatchelf --add-needed 你的目录/libpthread.so.0 ./pwn (如果提示没有libpthread.so.0的话)#后来发现最好的命令、
patchelf --set-rpath 你的文件目录/ld-linux-x86-64.so.2 ./pwn

大功告成。

尾声

动态调试是pwn中必不可少的重要步骤,而patch则是让我们能够动态调试的必由之路。欢迎有任何问题在评论区提出,我们将继续努力走向更高处。

当你没有符号表?
https://www.cnblogs.com/9man/p/17741818.html

http://www.jsqmd.com/news/558445/

相关文章:

  • 灵感画廊惊艳效果:宣纸UI交互下生成的书法题跋+水墨插画融合作品
  • 为RVC模型开发Web图形界面(GUI):使用Python的Qt框架
  • AgentCPM研报生成全攻略:从快速部署到参数调优,小白也能变专家
  • 造相Z-Image文生图模型快速试用:10秒生成高清图片,简单易用
  • AtlasOS系统Xbox控制器驱动问题解决方案:从诊断到长效维护
  • 告别手动测试!用JMeter参数化+断言,10分钟搞定iHRM登录接口的完整测试流程
  • MogFace人脸检测模型-WebUI多场景:远程办公系统会议发言人自动聚焦
  • Phi-3-vision-128k-instruct智能体(Agent)开发入门:基于Skills构建自动化任务流
  • 手把手教你用Ozone和J-Link调试FreeRTOS项目(含常见问题解决)
  • FLUX.1-dev完整教程:从镜像获取、资源监控、故障排查到性能调优全覆盖
  • IndexTTS-2-LLM新手教程:从部署到生成,完整流程详解
  • 别再手写递归了!用微信小程序自定义组件封装一个可复用的树形菜单(附完整代码)
  • 保姆级教程:用STM32标准库配置F105的双CAN(含引脚重映射与500K波特率计算)
  • 基于STM32的对射式红外传感器仿真电路设计与实现
  • KMP
  • coze-loop真实体验:粘贴Python代码,AI自动重构+详细解释
  • ARM汇编编程实战:5种分支跳转指令的妙用与避坑指南
  • PotPlayer高效录制Switch游戏画面:从采集卡配置到无干扰录制全攻略
  • 如何系统化构建微积分知识体系?开源资源整合指南
  • Qwen3-VL量化版实测:8bit精度仅降0.13%的奥秘
  • 告别Swagger原生UI!用Knife4j给你的SpringBoot API文档做个‘美容’
  • 成都别墅设计品牌东山艺锦全案定制详解:乡村别墅设计公司/别墅设计公司排行榜/别墅设计工作室/四川别墅设计/大宅设计公司排行榜/选择指南 - 优质品牌商家
  • 如何在树莓派上跑通TensorFlow Lite模型?从转换到部署的保姆级教程
  • 故障排除手册:DeOldify部署与运行中的常见错误及解决方案
  • DeerFlow参数详解:vLLM服务日志排查(llm.log/bootstrap.log)实战
  • PyTorch 2.8镜像部署教程:在/workspace中组织项目结构的最佳实践
  • 企业IT必看:PassCore归档后,还有哪些开源AD密码管理替代方案?
  • Linux /tmp 目录特性与应用
  • 避开OpenBCI GUI的坑:手把手教你稳定采集BDF脑电信号,并导入EEGLAB分析
  • Redis:不只是缓存那么简单(一)