0

0

Composer怎么校验文件完整 Composer怎么检查包签名安全【校验】

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-03-16 18:05:02

|

948人浏览过

|

来源于php中文网

原创

Composer 默认不校验网络传输层完整性,仅在 install/update 时比对 lock 文件中的 dist.sha256 与解压后文件哈希,且仅限 dist 包(zip/tar),不覆盖 source 包(git clone)。

composer怎么校验文件完整 composer怎么检查包签名安全【校验】

composer install 时怎么自动校验文件完整性

Composer 默认不校验下载包的文件哈希(如 SHA256),只比对 composer.lock 中记录的 dist.sha256 和实际解压后文件的哈希——但这个校验只在安装/更新时触发,且仅限于 dist 包(zip/tar),不覆盖 source 包(git clone)。关键在于:它不做网络传输层校验,也不验证包发布者签名。

实操建议:

  • 确保项目启用 composer install --prefer-dist(默认行为),否则走 git clone 就完全绕过哈希校验
  • 不要手动删掉 vendor/ 后用 composer install --no-scripts --no-plugins 跳过校验步骤——这会让 Composer 跳过哈希比对逻辑
  • 检查 composer.lock 是否包含 "sha256": "..." 字段:没有说明该包未发布 dist 包,或你正用着旧版 Composer(

composer verify-signature 能不能验包签名

composer verify-signature 这个命令根本不存在。Composer 官方至今(v2.7.x)不支持 PGP 或其他数字签名机制来验证包发布者身份。所谓“签名校验”是常见误解,源于混淆了 Packagist 的「签名 API」(仅供 packagist.org 内部使用)和用户端能力。

常见错误现象:

阿里妈妈·创意中心
阿里妈妈·创意中心

阿里妈妈营销创意中心

下载
  • 搜到第三方插件如 composer/composer-signature-checker,但已多年未维护,且依赖废弃的 openssl_pkey_get_public 方式,不兼容 PHP 8.1+
  • 试图在 composer.json 里写 "signature": "..." 字段——Composer 会直接忽略它
  • 认为 composer update --lock 会重新签名 lock 文件——它只会重写时间戳,不生成任何密码学签名

想真正确保包来源可信,只能靠这三件事

不是 Composer 不够好,而是 PHP 生态没把签名当基础设施。目前唯一可行路径是组合控制:

  • 强制所有包走 Packagist 官方源(禁用 repositories 自定义源),因为 Packagist 会对上传包做基础扫描和哈希存档
  • composer audit(Composer 2.5+)查已知漏洞,它会调 Packagist 的安全告警 API,虽不验签名,但能拦截已被标记为恶意的包版本
  • 在 CI 中加一步:composer show --locked --format=json | jq -r '.packages[] | select(.name | startswith("monolog/")) | .dist.sha256',再用 shasum -a 256 vendor/monolog/monolog/CHANGELOG.md 手动比对——适合高敏感项目,但得自己维护白名单和路径映射

为什么 vendor 目录里看不到 .sig 或 .asc 文件

因为 Packagist 从不下发签名文件。它只在 API 返回中附带 dist.sha256dist.reference(git commit hash),而这两个值都写死在 composer.lock 里。你看到的每个包目录下都没有签名相关元数据,这不是漏了,是设计如此。

容易被忽略的点:

  • composer install--dry-run 模式不会触发哈希校验,它只模拟流程,别拿它测试完整性逻辑
  • 私有 Packagist 镜像(如 Satis、Private Packagist)若没开启 enable-dist,会导致所有包退化为 git clone,彻底丢失哈希校验能力
  • PHP 的 phar.readonly = On(默认)会影响某些包的运行时校验逻辑,但它和 Composer 下载阶段的完整性校验无关

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
composer是什么插件
composer是什么插件

Composer是一个PHP的依赖管理工具,它可以帮助开发者在PHP项目中管理和安装依赖的库文件。Composer通过一个中央化的存储库来管理所有的依赖库文件,这个存储库包含了各种可用的依赖库的信息和版本信息。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

162

2023.12.25

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

457

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

549

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

337

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

83

2025.09.10

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

888

2023.07.31

python中的format是什么意思
python中的format是什么意思

python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

465

2024.06.27

自建git服务器
自建git服务器

git服务器是目前流行的分布式版本控制系统之一,可以让多人协同开发同一个项目。本专题为大家提供自建git服务器相关的各种文章、以及下载和课程。

999

2023.07.05

chatgpt使用指南
chatgpt使用指南

本专题整合了chatgpt使用教程、新手使用说明等等相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.03.16

热门下载

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

精品课程

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

共86课时 | 3.5万人学习

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

共28课时 | 2.6万人学习

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

共93课时 | 7.6万人学习

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

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