今天给大家介绍的是一款名叫GDBFrontend的工具,这是一款GUI调试工具,该工具易于使用,并且灵活可扩展,广大研究人员可以根据自己的需求来对GDBFrontend进行功能扩充。
工具安装
Debian安装(Debian / Ubuntu / KDE Neon)
如果你使用的是基于Debian发行版的操作系统平台,你可以使用Deb包来安装GDBFrontend。
广大用户可以使用下列命令完成工具安装:
代码语言:javascript复制echo "deb [trusted=yes]https://oguzhaneroglu.com/deb/./" | sudo tee -a /etc/apt/sources.list > /dev/null
sudo apt update
sudo apt install gdbfrontend
通过apt完成安装后,我们还需要使用apt upgrade来完成新版本更新,获取更新的命令如下:
代码语言:javascript复制sudo apt update
sudo apt upgrade gdbfrontend
接下来,我们就可以使用下列命令来运行GDBFrontend了:
代码语言:javascript复制gdbfrontend
GIT安装
当然了,广大研究人员也可以直接下载该项目的最新版本源码,然后配置并运行GDBFrontend。
工具要求:
1、GDB => 8.2 (python3) 2、python3 3、tmux
此时,我们可以使用下列命令将项目源码克隆至本地,然后安装并使用GDBFrontend:
代码语言:javascript复制git clonehttps://github.com/rohanrhu/gdb-frontend.gitgdb-frontend
cd gdb-frontend
./gdbfrontend
接下来,使用下列命令运行工具:
代码语言:javascript复制http://127.0.0.1:5551/terminal/
如果你不需要配合终端使用的话,可以运行下列命令:
代码语言:javascript复制http://127.0.0.1:5551/
我们还可以使用下列命令打开GBD Shell:
代码语言:javascript复制tmux a -t gdb-frontend
Flatpak
在新版本的GDBFrontend中,还会添加针对Flatpak包的支持。
./gdbfrontend
代码语言:javascript复制$ gdbfrontend --help
GDBFrontend is a easy, flexible and extensionable gui debugger.
Options:
--help, -h: 显示帮助信息
--version, -v: 显示版本信息
--gdb-executable=PATH, -g PATH: 指定GDB可执行文件路径
--tmux-executable=PATH, -tmux PATH: 指定Tmux可执行文件路径
--terminal-id=NAME, -t NAME: 指定tmux 终端识别符名称
--verbose, -V: 启用verbose 输出
参数选项
代码语言:javascript复制--help, -h
显示帮助信息
代码语言:javascript复制--version, -v
显示版本信息
代码语言:javascript复制--gdb-executable=PATH, -g PATH
指定GDB可执行文件路径,例如:gdbfrontend —gdb-executable=/path/to/gdb。(可选项)
代码语言:javascript复制--tmux-executable=PATH, -tmux PATH
指定Tmux可执行文件路径,例如:gdbfrontend —tmux-executable=/path/to/tmux。(可选项)
代码语言:javascript复制--terminal-id=PATH, -t PATH
指定tmux 终端识别符名称(ID),例如:gdbfrontend —terminal-id=terminal-name。(默认: gdb-frontend)
代码语言:javascript复制--verbose, -v
启用verbose 输出
错误解决
有的时候GDB和GDBFrontend可能会以非正常状态关闭,此时我们可以使用下列命令终止gdb-frontend Shell:
代码语言:javascript复制tmux kill-session -t gdb-frontend
插件系统开发
插件样本
下面给出的是一个插件样本,可以在项目目录plugins/hello中的hello文件中找到相关代码。
首先,我们需要找到config.py文件,然后取消下列代码的注释:
代码语言:javascript复制disabled_plugins = ["hello"]
GDBFrontend的插件都存储在plugins/目录中,典型的插件文件结构如下:
代码语言:javascript复制plugins/hello/frontend/html/hello.htmljs/hello.jscss/hello.cssurl_modules/api.pyconfig.pyurls.pyhello.py
插件文件-config.py
一个插件文件应当包含的基础信息如下:
代码语言:javascript复制DESCRIPTION = "Example GDBFrontend plugin."AUTHOR = "Oğuzhan Eroğlu <rohanrhu2@gmail.com> (https://oguzhaneroglu.com/)"HOMEPAGE = "https://github.com/rohanrhu/gdb-frontend"VERSION = [0, 0, 1]
hello.py样本代码:
代码语言:javascript复制import importlibimport plugingdb = importlib.import_module("gdb")class HelloPlugin(plugin.GDBFrontendPlugin):def __init__(self):plugin.GDBFrontendPlugin.__init__(self)def loaded(self):gdb.events.new_objfile.connect(self.gdb_on_new_objfile)def unloaded(self):gdb.events.new_objfile.disconnect(self.gdb_on_new_objfile)def gdb_on_new_objfile(self, event):print("[HELLO] Event: new_objfile:", event)
工具运行截图
许可证协议
本项目的开发与发布遵循GNU General Public License v3 (GPL-3)开源许可证协议。
项目地址
GDBFrontend:【GitHub传送门】
* 参考来源:rohanrhu,FB小编Alpha_h4ck编译,转载请注明来自FreeBuf.COM