问题描述
如何在设置了环境变量的情况下运行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%)。