English | 简体中文
SBOM-TOOL 是通过源码仓库、代码指纹、构建环境、制品信息、制品内容、依赖组件等多种维度信息,为软件项目生成软件物料清单(SBOM)的一款CLI工具。
开发语言
是否支持
C/C++
是
Java
是
C#
是
Dart
是
Golang
是
Javascript
是
Objective-C
是
Php
是
Python
是
Ruby
是
Rust
是
Swift
是
Lua
是
现已支持以下编程语言相关的配置文件解析、二进制包解析,后续会逐步支持更多的编程语言。
包类型
包管理器
解析文件
是否支持依赖图谱
maven
pom.xml
*.jar
*.war
[graph]maven-dependency-tree.txt(mvn dependency:tree -DoutputFile=maven-dependency-tree.txt)
是
maven
*.gradle
.gradle.lockfile
[graph]gradle-dependency-tree.txt(gradlew gradle-baseline-java:dependencies > gradle-dependency-tree.txt)
是
conan
conanfile.txt
conan.lock
[graph]conan-graph-info.json(conan graph info -f json > conan-graph-info.json)
是
npm
package.json
package-lock.json
否
npm
[graph]yarn.lock
是
npm
[graph]pnpm.lock
是
golang
go.mod
Go Binary file
[graph]go-mod-graph.txt(go mod graph > go-mod-graph.txt)
是
golang
glide.yml
glide.yaml
否
golang
Godeps.json
否
golang
Gopkg.toml
否
golang
*/vendor/manifest
否
pypi
Pipfile.lock
*dist-info/METADATA
PKG-INFO
*requirements*.txt
setup.py
[graph]pipenv-graph.txt(pipenv graph > pipenv-graph.txt)
是
pypi
[graph]poetry.lock
是
conda
environment.yml
environment.yaml
package-list.txt
否
composer
composer.json
composer.lock
否
cargo
Cargo.toml
[graph]Cargo.lock
Rust Binary file
是
carthage
Cartfile
Cartfile.resolved
否
swift
Package.swift
否
cocoapods
Podfile.lock
Podfile
*.podspec
是
gem
[graph]Gemfile.lock
Gemfile
*.gemspec
是
nuget
[graph]*.deps.json
*.csproj
*.vbproj
*.fsproj
*.vcproj
*.nuget.dgspec.json
*.nuspec
packages.json
packages.lock.json
是
pub
[graph]pub-deps.json(dart pub deps --json > pub-deps.json)
pubspec.lock
pubspec.yaml
是
rpm
*.spec
否
deb
*.deb
*.control
否
lua
*.rockspec
否
bower
*.spec
否
下载源码编译(需要 go 1.18
及以上版本)
git clone git@gitee.com:JD-opensource/sbom-tool.git
cd sbom-tool
make
默认生成多个系统架构的程序二进制包
或者通过 go install 安装
go install gitee.com/JD-opensource/sbom-tool/cmd/sbom-tool@latest
或者通过下载二进制文件安装: SBOM-TOOL发行版
子命令
功能
help
工具帮助手册
artifact
采集软件包制品信息
assembly
把各阶段生成的文档组装为SBOM文档
completion
为指定的shell生成自动完成脚本
convert
转换SBOM文档格式
env
生成环境信息
generate
生成SBOM文档
package
收集包依赖项
source
收集源代码信息
validate
验证SBOM文档格式
info
获取工具介绍信息
modify
修改SBOM文档属性
参数
短参数
描述
使用样例
--log-level
指定日志级别,包括 debug
、info
、warn
、error
--log-level info
--log-path
指定日志路径,默认在用户主目录下自动生成日志目录及日志文件($home/sbom-tool/sbom-tool.log)
--log-path /tmp/sbom.log
--quiet
-q
无控制台输出
--quiet
-q
--ignore-dirs
要忽略的目录,跳过所有点目录,以逗号分隔。示例:NODE_MODULES,LOGS
--ignore-dirs log,logs
--language
-l
指定语言(目前支持:java
,cpp
)(默认为“*”)
--language java
-l cpp
--parallelism
-m
并发度(默认为8
)
--parallelism 4
-m 9
--output
-o
指定结果输出文件存放路径及名称,默认会在当前目录下自动生成
--output /tmp/sbom.json
--src
-s
指定源代码存放路径,默认为当前目录
--src /tmp/sbomtool/src/
--path
-p
指定项目工程主目录;assembly子命令中用于指定各阶段临时文档路径
--path /tmp/sbomtool/
--dist
-d
指定制品存放路径,默认为当前目录
--dist /tmp/sbomtool/bin/
--format
-f
指定SBOM文档格式(目前支持:xspdx-json
、spdx-json
、spdx-tagvalue
)(默认为spdx-json
)
--format spdx-json
-f spdx-json
--input
-i
指定SBOM文档作为输入
--input /tmp/sbom.jsom
--algorithm
-a
用于指定生成SBOM文档标识的算法(目前支持:SHA1
、SHA256
、SM3
)(默认为SM3
)
--algorithm SHA256
规范
格式
SBOM文档格式
是否支持
XSPDX
JSON
xspdx-json
已支持
SPDX
JSON
spdx-json
已支持
SPDX
TagValue
spdx-tagvalue
已支持
XSPDX 是基于SPDX扩展的SBOM格式规范
生成SBOM文档并指定格式
sbom-tool generate -m 4 -p ${project_path} -s ${src_path} -d ${dist_path} -o sbom.spdx.json -f spdx-json --ignore-dirs .git -n ${name} -v ${version} -u ${supplier} -b ${namespace}
获取工具介绍信息
sbom-tool info
更多使用案例,详见文档
详见 开发指南文档
如果在使用中遇到问题,欢迎您向我们提交ISSUE。
SBOM-TOOL 是一款开源的软件成分分析工具,期待您的贡献。
此项目是在 MulanPSL2 下授权的,有关详细信息,请参阅许可证文件。
原网址: 访问
创建于: 2024-05-29 16:25:34
目录: default
标签: 无
未标明原创文章均为采集,版权归作者所有,转载无需和我联系,请注明原出处,南摩阿彌陀佛,知识,不只知道,要得到
java windows火焰图_mob64ca12ec8020的技术博客_51CTO博客 - 在windows下不可行,不知道作者是怎样搞的 监听SpringBoot 服务启动成功事件并打印信息_监听springboot启动完毕-CSDN博客 SpringBoot中就绪探针和存活探针_management.endpoint.health.probes.enabled-CSDN博客 u2u转换板 - 嘉立创EDA开源硬件平台 Spring Boot 项目的轻量级 HTTP 客户端 retrofit 框架,快来试试它!_Java精选-CSDN博客 手把手教你打造一套最牛的知识笔记管理系统! - 知乎 - 想法有重合-理论可参考 安宇雨 闲鱼 机械键盘 客制化 开贴记录 文本 linux 使用find命令查找包含某字符串的文件_beijihukk的博客-CSDN博客_find 查找字符串 ---- mac 也适用 安宇雨 打字音 记录集合 B站 bilibili 自行搭建 开坑 真正的客制化 安宇雨 黑苹果开坑 查找工具包maven pom 引用地 工具网站 Dantelis 介绍的玩轴入坑攻略 --- 关于轴的一些说法 --- 非官方 ---- 心得而已 --- 长期开坑更新 [本人问题][新开坑位]关于自动化测试的工具与平台应用 机械键盘 开团 网站记录 -- 能做一个收集的程序就好了 不过现在没时间 -- 信息大多是在群里发的 - 你要让垃圾佬 都去一个地方看难度也是很大的 精神支柱 [超级前台]sprinbboot maven superdesk-app 记录 [信息有用] [环境准备] [基本完成] [sebp/elk] 给已创建的Docker容器增加新的端口映射 - qq_30599553的博客 - CSDN博客 [正在研究] Elasticsearch, Logstash, Kibana (ELK) Docker image documentation elasticsearch centos 安装记录 及 启动手记 正式服务器 39 elasticsearch 问题合集 不断更新 6.1.1 | 6.5.1 两个版本 博客程序 - 测试 - bug记录 等等问题 laravel的启动过程解析 - lpfuture - 博客园 OAuth2 Server PHP 用 Laravel 搭建带 OAuth2 验证的 RESTful 服务 | Laravel China 社区 - 高品质的 Laravel 和 PHP 开发者社区 利用Laravel 搭建oauth2 API接口 附 Unauthenticated 解决办法 - 煮茶的博客 - SegmentFault 思否 使用 OAuth2-Server-php 搭建 OAuth2 Server - 午时的海 - 博客园 基于PHP构建OAuth 2.0 服务端 认证平台 - Endv - 博客园 Laravel 的 Artisan 命令行工具 Laravel 的文件系统和云存储功能集成 浅谈Chromium中的设计模式--终--Observer模式 浅谈Chromium中的设计模式--二--pre/post和Delegate模式 浅谈Chromium中的设计模式--一--Chromium中模块分层和进程模型 DeepMind 4 Hacking Yourself README.md update 20211011
Laravel China 简书 知乎 博客园 CSDN博客 开源中国 Go Further Ryan是菜鸟 | LNMP技术栈笔记 云栖社区-阿里云 Netflix技术博客 Techie Delight Linkedin技术博客 Dropbox技术博客 Facebook技术博客 淘宝中间件团队 美团技术博客 360技术博客 古巷博客 - 一个专注于分享的不正常博客 软件测试知识传播 - 测试窝 有赞技术团队 阮一峰 语雀 静觅丨崔庆才的个人博客 软件测试从业者综合能力提升 - isTester IBM Java 开发 使用开放 Java 生态系统开发现代应用程序 pengdai 一个强大的博主 HTML5资源教程 | 分享HTML5开发资源和开发教程 蘑菇博客 - 专注于技术分享的博客平台 个人博客-leapMie 流星007 CSDN博客 - 舍其小伙伴 稀土掘金 Go 技术论坛 | Golang / Go 语言中国知识社区
最新评论