利用pwntools脚本联动内置gdb函数优雅的调试docker中的pwn程序
ZLSF 安全工具 529浏览 · 2025-04-15 11:47

起源:

在CTF中的PWN模块中,我们时常需要用的到gdb来联动exp脚本调试pwn程序,在pwntools的内置函数gdb.attach()上与本地调试非常方便实现,但是本地环境与pwn程序编译时的原生环境还是有所差距,并且一些特殊架构如mips等,或者pwn程序使用了C++的库,利用pathcelf替换libc库就有点力不从心了。

在此之前我尝试过其他师傅的办法,其中最好用的pipe+ tmux 的组合,但是这个办法实测必须要先输入才能输出(pipe有阻塞的特性)。所以仍然不太好用。如果要是在docker内重新安装pwn环境+pwngdb插件会很麻烦(主要是pwngdb难以安装)。

所以我想了一个办法,能对任意docker能运行的镜像系统都能提供一个无缝调试pwn程序体验的办法。非常时候在做题的时候建立临时docker环境用来调试pwn程序。

本文内容截至2025年4月15日仍然有效。

步骤:

环境:ubuntu-24.04 + virtualbox7.1.6

前提:已经安装好基础pwn环境和docker环境。

在当前目录下创建Dockerfile文件,内容如下:

Bash
复制代码
使用docker构建镜像(请将当前用户加入docker用户组):

Bash
复制代码
创建docker容器并赋予一定权限还要开放端口:

在宿主机将pwn文件复制到docker中:

在docker中的/tmp目录下有一个run.sh文件和pwn文件,运行run.sh文件来启用pwn运行在端口9999:

在你的exp脚本中添加一下函数:

调用方法为:

和正常调试一样,运行脚本 :

gdbremote函数会弹出两个窗口,一个是gdbserver的不用管,另外一个是gdb这个和正常使用gdb.attach(p)是一样的,目前测试和本地调试几乎没有区别。在pause时需要先下断点再让exp运行,否则很有可能停不在你想停的地方。

gdb中使用b *0x??????然后c继续程序,然后才能让exp继续运行。

gdb通过CTRL + D退出后正常来说弹出的两个窗口都会关闭,此时可以重新运行脚本进行调试。

效果:

效果.png


0 条评论
某人
表情
可输入 255
目录