GDBFrontend:一款灵活可扩展的GUI调试工具

Unix/Linux > 物联网安全 文章作者:无名投稿者 2020-03-29 18:50 阅读: loading...

今天给大家介绍的是一款名叫GDBFrontend的工具,这是一款GUI调试工具,该工具易于使用,并且灵活可扩展,广大研究人员可以根据自己的需求来对GDBFrontend进行功能扩充。

工具安装

Debian安装(Debian / Ubuntu / KDE Neon)

如果你使用的是基于Debian发行版的操作系统平台,你可以使用Deb包来安装GDBFrontend。

广大用户可以使用下列命令完成工具安装:

echo "deb [trusted=yes]https://oguzhaneroglu.com/deb/./" | sudo tee -a /etc/apt/sources.list > /dev/nullsudo apt updatesudo apt install gdbfrontend

通过apt完成安装后,我们还需要使用apt upgrade来完成新版本更新,获取更新的命令如下:

sudo apt updatesudo apt upgrade gdbfrontend

接下来,我们就可以使用下列命令来运行GDBFrontend了:

gdbfrontend

GIT安装

当然了,广大研究人员也可以直接下载该项目的最新版本源码,然后配置并运行GDBFrontend。

工具要求:

1、GDB => 8.2 (python3)

2、python3

3、tmux

此时,我们可以使用下列命令将项目源码克隆至本地,然后安装并使用GDBFrontend:

git clonehttps://github.com/rohanrhu/gdb-frontend.gitgdb-frontendcd gdb-frontend./gdbfrontend

接下来,使用下列命令运行工具:

http://127.0.0.1:5551/terminal/

如果你不需要配合终端使用的话,可以运行下列命令:

http://127.0.0.1:5551/

我们还可以使用下列命令打开GBD Shell:

tmux a -t gdb-frontend

Flatpak

在新版本的GDBFrontend中,还会添加针对Flatpak包的支持。

./gdbfrontend

$ gdbfrontend --helpGDBFrontend 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 输出

参数选项

--help, -h

显示帮助信息

--version, -v

显示版本信息

--gdb-executable=PATH, -g PATH

指定GDB可执行文件路径,例如:gdbfrontend –gdb-executable=/path/to/gdb。(可选项)

--tmux-executable=PATH, -tmux PATH

指定Tmux可执行文件路径,例如:gdbfrontend –tmux-executable=/path/to/tmux。(可选项)

--terminal-id=PATH, -t PATH

指定tmux 终端识别符名称(ID),例如:gdbfrontend –terminal-id=terminal-name。(默认: gdb-frontend)

--verbose, -v

启用verbose 输出

错误解决

有的时候GDB和GDBFrontend可能会以非正常状态关闭,此时我们可以使用下列命令终止gdb-frontend Shell:

tmux kill-session -t gdb-frontend

插件系统开发

插件样本

下面给出的是一个插件样本,可以在项目目录plugins/hello中的hello文件中找到相关代码。

首先,我们需要找到config.py文件,然后取消下列代码的注释:

disabled_plugins = ["hello"]

GDBFrontend的插件都存储在plugins/目录中,典型的插件文件结构如下:

plugins/hello/frontend/html/hello.htmljs/hello.jscss/hello.cssurl_modules/api.pyconfig.pyurls.pyhello.py

插件文件-config.py

一个插件文件应当包含的基础信息如下:

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样本代码:

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)开源许可证协议。

已获取点赞 +0

评论 点击评论