HardeningMeter:一款针对二进制文件和系统安全强度的开源工具

关于HardeningMeter

HardeningMeter是一款针对二进制文件和系统安全强度的开源工具,该工具基于纯Python开发,经过了开发人员的精心设计,可以帮助广大研究人员全面评估二进制文件和系统的安全强化程度。

功能特性

其强大的功能包括全面检查各种二进制利用保护机制,包括 Stack Canary、RELRO、随机化(ASLR、PIC、PIE)、None Exec Stack、Fortify、ASAN、NX bit。此工具适用于所有类型的二进制文件,并能够提供有关每个二进制文件强化状态的准确信息,识别值得关注的二进制文件和具有强大安全措施的二进制文件。

HardeningMeter支持所有 Linux 发行版和机器可读输出,并且能够将数据输出结果以表格形式打印到屏幕上或导出到csv文件。

工具要求

1、readelf和file命令;

2、Python 3.x;

3、pip;

4、tabulate;

工具安装

由于该工具基于Python 3开发,因此我们首先需要在本地设备上安装并配置好最新版本的Python 3环境。

接下来,广大研究人员可以直接使用下列命令将该项目的最新版本源码克隆至本地:

复制代码
git clone https://github.com/OfriOuzan/HardeningMeter.git

工具使用

工具参数

-f --file:指定需要扫描的文件,参数可以用空格分隔多个文件;

-d --directory:指定要扫描的目录,该参数检索一个目录并递归扫描所有 ELF 文件;

-e --external:指定是否要添加外部检查(默认为False);

-m --show_missing:根据顺序打印,仅打印缺少安全强化机制且需要额外注意的文件;

-s --system:指定是否要扫描系统强化方法;

-c --csv_format':指定是否要将结果保存到 csv 文件(默认情况下,结果以表格形式打印到 stdout);

执行结果

HardeningMeter 的结果以表格形式打印,包含 3 种不同的状态:

1、(X)------此状态表示二进制强化机制已被禁用;

2、(V)------此状态表示二进制强化机制已启用;

3、(-)------此状态表示二进制强化机制与此特定情况无关;

注意事项

当 Linux 上的默认语言不是英语时,请确保在调用脚本之前添加"LC_ALL=C"。

工具运行演示

扫描"/usr/bin"目录、"/usr/sbin/newusers"文件和本地系统,并将结果导出到csv文件:

复制代码
python3 HardeningMeter.py -f /bin/cp -s

许可证协议

本项目的开发与发布遵循AGPL-3.0开源许可协议。

项目地址

HardeningMeter :【GitHub传送门

参考资料

https://medium.com/@ofriouzan/part-2-compiler-level-security-mechanisms-gcc-d01246b8d157

https://medium.com/@ofriouzan/part-3-kernel-level-security-mechanisms-097e8b8ecefa

相关推荐
溯Sec1 天前
shodan(五)连接Mongodb数据库&Jenkins&org、net、查看waf命令
网络·安全·web安全·网络安全·系统安全·网络攻击模型·安全架构
溯Sec2 天前
搜索引擎之shodan(一):初始化及安装
网络·安全·web安全·搜索引擎·网络安全·系统安全·安全架构
打码人的日常分享3 天前
系统安全设计规范,安全设计制度,系统安全管理制度(word原件)
大数据·系统安全·需求分析·设计规范·规格说明书
zzzhpzhpzzz5 天前
设计模式——代理模式
设计模式·系统安全·代理模式
广东性感学术大蟑螂=V=5 天前
2025年计算机视觉研究进展与应用国际学术会议 (ACVRA 2025)
人工智能·计算机视觉·阿里云·机器人·自动化·系统安全
宁_3315 天前
十一章.系统安全及应用
安全·系统安全
易云码6 天前
【信息安全设计】系统安全设计方案,系统安全保护设施设计实施方案(Word原件)
java·数据库·人工智能·安全·系统安全
IT-民工211107 天前
Linux系统安全配置
linux·运维·系统安全
威迪斯特8 天前
linux系统安全:开源的反病毒工具ClamAV的安装配置使用和维护介绍
linux·运维·centos·系统安全·扫描·病毒·木马