Skip to content

goby 最新版 指纹提取

字数
532 字
阅读时间
3 分钟
更新日期
8/5/2021

最近想看看最新版的goby指纹提取有没有什么变化。

我们知道了goby的指纹规则是yara写的,并且保存在了crules文件中。

下载了最新版本Beta1.8.279的Goby,显示的更新日期是2021 6.18

查看是用go几版本写的

之前goby内嵌资源用的statik第三方库,尝试搜索这个字符串已经搜不到了。

在go1.16,嵌入资源有个官方实现,叫go embed,可以根据在二进制中搜索embed.FS来确认是否使用了这个特性,所以搜索就知道goby用的这种方式将资源嵌入了程序。

然后自己可以测试一下,使用了go embed,内嵌的资源是怎样的形式存储的,我直接给出我的结论,直接明文显示在二进制中。

搜索YARA就能找到yara的头

往下翻就能看到熟悉的规则~

另外看到goby使用了这个库https://github.com/hillu/go-yara,应该就是用来解析规则的,看这个库的实现,它只是c版本源码的封装。

如果只是想使用把yara提取出来用这个库应该就能用了,但我的目的还是把指纹提取出来。

后面规则的提取就和我之前文章中的一样了,完整提取代码

python
filename = r"goby-cmd.exe"

with open(filename, 'rb') as f:
    data = f.read()

start = data.index(b"default\x00fofa")
end = data.index(b"\x00" * 16, start)
data = data[start:end]

datas = data.split(b"rule_id")[1:]

sep = b"\x00"
options_set = set()
results = []

for item in datas:
    ff = item.split(sep)
    # print(ff)
    rule_id = ff[1].decode()
    level = ff[3].decode()
    softhard = ff[5].decode()
    product = ff[7].decode()
    company = ff[9].decode()
    category = ff[11].decode()
    parent_category = ff[13].decode()
    # print(rule_id, level, softhard, product, company, category, parent_category)
    dd = {
        "rule_id": rule_id,
        "level": level,
        "softhard": softhard,
        "product": product,
        "company": company,
        "category": category,
        "parent_category": parent_category,
        "rules": []
    }
    bb = b'\x00'.join(ff[14:])
    s = bb.split(b'\x00\x00\x00\x00\x73\x00')
    _rr2 = []
    for rr in s:
        _rules = []
        if not rr.startswith(b'fofa'):
            continue
        index = 0
        while index < len(rr):
            prefixx = b"fofa\x00"
            try:
                start = rr.index(prefixx, index) + len(prefixx)
            except:
                break
            end = rr.index(b'\x00', start)
            match_way = rr[start:end].decode()
            # print("match_way", match_way)
            _length = rr[end + 1]
            content = rr[end + 9:end + 9 + _length]
            index += end + 9 + _length
            # _rules.append(match_way + ":" + content.decode('utf-8', errors="ignore"))
            _rules.append(
                {
                    "match": match_way,
                    "content": content.decode('utf-8', errors="ignore")
                }
            )
        _rr2.append(_rules)
    dd["rules"] = _rr2
    results.append(dd)

print(results)

with open("fofa.json", "w", encoding="utf-8") as f:
    import json

    json.dump(results, f, ensure_ascii=False)

撰写

布局切换

调整 VitePress 的布局样式,以适配不同的阅读习惯和屏幕环境。

全部展开
使侧边栏和内容区域占据整个屏幕的全部宽度。
全部展开,但侧边栏宽度可调
侧边栏宽度可调,但内容区域宽度不变,调整后的侧边栏将可以占据整个屏幕的最大宽度。
全部展开,且侧边栏和内容区域宽度均可调
侧边栏宽度可调,但内容区域宽度不变,调整后的侧边栏将可以占据整个屏幕的最大宽度。
原始宽度
原始的 VitePress 默认布局宽度

页面最大宽度

调整 VitePress 布局中页面的宽度,以适配不同的阅读习惯和屏幕环境。

调整页面最大宽度
一个可调整的滑块,用于选择和自定义页面最大宽度。

内容最大宽度

调整 VitePress 布局中内容区域的宽度,以适配不同的阅读习惯和屏幕环境。

调整内容最大宽度
一个可调整的滑块,用于选择和自定义内容最大宽度。

聚光灯

支持在正文中高亮当前鼠标悬停的行和元素,以优化阅读和专注困难的用户的阅读体验。

ON开启
开启聚光灯。
OFF关闭
关闭聚光灯。

聚光灯样式

调整聚光灯的样式。

置于底部
在当前鼠标悬停的元素下方添加一个纯色背景以突出显示当前鼠标悬停的位置。
置于侧边
在当前鼠标悬停的元素旁边添加一条固定的纯色线以突出显示当前鼠标悬停的位置。