如何在GDB下运行环境变量设置为文件内容的程序?

问题描述

如何在设置了环境变量的情况下运行gdb,如下面的示例所示?

gdb (env -i SHELLCODE="`cat ~/shellcode.bin`" ./vulnerable)

解决方法

通常,您可以在启动要调试的程序之前使用set environment command

set environment MYVAR abc

但是,从您的问题来看,您似乎想要从文件中获取环境变量的内容,并且无法从GDB Shell中做到这一点。但是,您可以使用已设置的变量来启动GDB,并且在启动程序进行调试时将保留该变量。您可以使用show environment命令进行验证。

$ MYVAR="$(cat x.txt)" gdb ./vulnerable

或:

$ export MYVAR="$(cat x.txt)"
$ gdb ./vulnerable

甚至使用env

$ env -i MYVAR="$(cat x.txt)" gdb ./vulnerable

然后:

(gdb) show environment MYVAR
MYVAR=...
(gdb) run

您可能想检查一下您的shellcode是否不包含\x00个字节,因为这可能会导致一些问题(由于我没有测试,所以不确定100%)。