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

2020-03-29 90524人围观 系统安全

今天给大家介绍的是一款名叫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/null

sudo apt update

sudo apt install gdbfrontend

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

sudo apt update

sudo 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-frontend

cd 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 --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 输出

参数选项

--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.html

js/

hello.js

css/

hello.css

url_modules/

api.py

config.py

urls.py

hello.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 importlib

import plugin

gdb = 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

相关推荐
取消
Loading...

特别推荐

填写个人信息

姓名
电话
邮箱
公司
行业
职位
css.php