0

0

composer如何验证包签名?(SLSA与供应链安全初探)

穿越時空

穿越時空

发布时间:2026-03-10 15:13:49

|

223人浏览过

|

来源于php中文网

原创

composer install 校验包的 sha-256 完整性(dist.shasum)和 https 传输安全,不验证开发者数字签名;关键组件需手动验证 git tag 的 gpg 签名,并启用 packagist 元数据 gpg 验证(≥2.2 版本)。

composer如何验证包签名?(slsa与供应链安全初探)

Composer 本身不验证开发者数字签名,它验证的是包的完整性(shasum)和元数据来源(HTTPS + 可选 GPG),不是“谁签的”,而是“是不是原包、是不是从可信源来的”。

composer install 时到底校验了什么?

你执行 composer install 的那一刻,Composer 已经在后台做了两件事:

  • 比对 composer.lock 中每个包的 dist.shasum 和实际下载 ZIP/TAR 包的 SHA-256 值 —— 不匹配直接报错,提示 Signature mismatchpackage is corrupted
  • 强制走 HTTPS 连接仓库(如 https://repo.packagist.org),校验 TLS 证书链,防止中间人劫持或镜像投毒。

这不是“签名验证”,是“传输+存储双重哈希校验”。它能防篡改、防下载污染,但不能证明“这个包是 Laravel 官方亲手打包并签名发布的”。

想验证“谁发布的”?得靠 Git 标签 GPG 签名 + 手动操作

Composer 对 Git 仓库(VCS 类型依赖)不自动验签,但你可以自己验证维护者是否对发布版本打了可信 GPG 标签:

  • 先确保已导入作者公钥:gpg --keyserver keyserver.ubuntu.com --recv-keys ABCDEF1234567890
  • 克隆仓库:git clone https://github.com/vendor/package.git
  • 检出 tag 并验证:git tag -v v2.3.4 —— 输出含 Good signature 且密钥指纹匹配才可信;
  • 然后在 composer.json 中显式引用该 tag:"vendor/package": "dev-main#v2.3.4" 或通过 VCS 仓库配置 + minimum-stability: stable 锁定。

注意:如果项目没打 GPG tag,或者你没导入对应公钥,git tag -v 会显示 Can't check signature: No public key —— 这不是 Composer 的问题,是发布方未启用或你未准备验证环境。

蛙蛙写作——超级AI智能写作助手
蛙蛙写作——超级AI智能写作助手

蛙蛙写作辅助AI写文,帮助获取创意灵感,提供拆书、小说转剧本、视频生成等功能,是一款功能全面的AI智能写作工具。

下载

生产环境必须开启 Packagist 元数据 GPG 验证

Packagist 自 2021 年起对 packages.json 等元数据文件做 GPG 签名,Composer ≥ 2.2 支持自动校验。不启用,攻击者可能伪造搜索结果、注入恶意包链接:

  • 检查当前版本:composer --version(必须 ≥ 2.2);
  • 启用签名验证:composer config --global signing-key /path/to/packagist.pub
  • 公钥可从官方获取:curl -s https://packagist.org/keys/packagist.pub | gpg --dearmor > /usr/share/keyrings/packagist.gpg
  • 验证生效:运行 composer update -vvv,若看到 Verifying packages.json signature... 且无报错,说明成功。

漏掉这步,等于信任整个包索引页 —— 而索引页本身可能被供应链攻击污染。

别被 roave/composer-gpg-plugin 带偏方向

社区插件 roave/composer-gpg-plugin 听起来很安全,但它只在包维护者主动为每个 release 提交 GPG 签名的前提下才有效。现实中绝大多数 Packagist 包根本没配这个流程,装了也白装,还可能因签名缺失导致安装失败。

更务实的做法是:优先用 HTTPS + shasum 校验保底,关键组件(如支付 SDK、加密库)手动核验 Git tag 签名,再配合 composer audit 扫已知漏洞 —— 签名只是纵深防御的一环,不是银弹。

真正容易被忽略的是:composer.lock 文件必须提交到 Git,且每次更新都要人工审查 diff;否则,哪怕所有校验都通过,一个被悄悄替换的 lock 文件就能让整套验证形同虚设。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
laravel组件介绍
laravel组件介绍

laravel 提供了丰富的组件,包括身份验证、模板引擎、缓存、命令行工具、数据库交互、对象关系映射器、事件处理、文件操作、电子邮件发送、队列管理和数据验证。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

339

2024.04.09

laravel中间件介绍
laravel中间件介绍

laravel 中间件分为五种类型:全局、路由、组、终止和自定。想了解更多laravel中间件的相关内容,可以阅读本专题下面的文章。

293

2024.04.09

laravel使用的设计模式有哪些
laravel使用的设计模式有哪些

laravel使用的设计模式有:1、单例模式;2、工厂方法模式;3、建造者模式;4、适配器模式;5、装饰器模式;6、策略模式;7、观察者模式。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

772

2024.04.09

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

385

2024.04.10

laravel入门教程
laravel入门教程

本专题整合了laravel入门教程,想了解更多详细内容,请阅读专题下面的文章。

140

2025.08.05

laravel实战教程
laravel实战教程

本专题整合了laravel实战教程,阅读专题下面的文章了解更多详细内容。

85

2025.08.05

laravel面试题
laravel面试题

本专题整合了laravel面试题相关内容,阅读专题下面的文章了解更多详细内容。

79

2025.08.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

417

2026.03.04

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
第二十四期_PHP8编程
第二十四期_PHP8编程

共86课时 | 3.5万人学习

成为PHP架构师-自制PHP框架
成为PHP架构师-自制PHP框架

共28课时 | 2.6万人学习

第二十三期_PHP编程
第二十三期_PHP编程

共93课时 | 7.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号