0

0

composer如何检测依赖安全性_composer审计功能使用指南【教程】

尼克

尼克

发布时间:2026-01-24 16:46:02

|

872人浏览过

|

来源于php中文网

原创

不能。composer audit 仅检测 vendor/ 中已安装包,依赖 Symfony 安全数据库,不扫描未安装依赖或子依赖的子依赖,且私有包、fork 包默认跳过;需先运行 composer install/update,否则结果为空。

composer如何检测依赖安全性_composer审计功能使用指南【教程】

composer audit 能否直接检测全部依赖漏洞

不能。从 Composer 2.5 开始内置的 composer audit 命令只检查已安装的包(即 vendor/ 中实际存在的版本),且默认仅对接 Symfony Security Advisory Database,不包含 CVE/NVD 等通用漏洞库。它不会扫描你 composer.json 中声明但尚未安装的依赖,也不会检查子依赖的子依赖(除非它们被实际安装)。

  • 运行前必须先执行 composer installcomposer update,否则 vendor/ 为空,audit 结果为 “No vulnerabilities found”(即使有高危未装包)
  • 不支持 --ignore-platform-reqs 或离线模式下的深度校验
  • 对私有包、fork 包、本地 path repo 默认跳过,除非手动在 composer.json 中配置 "type": "package" 并显式提供安全元数据

如何让 composer audit 输出更详细的漏洞信息

--format=json--format=table 可改变输出结构,但真正提升信息量的是启用详细模式和指定数据库源:

  • composer audit --full:强制检查所有已安装包(包括 dev-only 包),而非仅生产依赖
  • composer audit --no-dev:排除开发依赖,缩小范围(适合 CI 中快速验证线上环境)
  • 设置环境变量 COMPOSER_AUDIT_DATABASE=https://your-internal-db.example/v1/advisories 可切换到自建或企业级漏洞库(需 API 兼容 Symfony 格式)
  • 若看到 Warning: No security advisories found for package xxx,说明该包不在 Symfony DB 中——不是“安全”,而是“未收录”,需人工核查

audit 报告中的 CVSS 分数和 severity 字段含义

Composer audit 输出的 severity 是 Symfony DB 自定义分级(low/medium/high/critical),**不等于 CVSS v3.x 原始评分**。它由 Symfony 安全团队人工评估,侧重实际利用难度与影响面,例如:

koly.club
koly.club

一站式社群管理工具

下载
  • critical:远程代码执行、未授权接管、密钥硬编码泄露等
  • high:SQL 注入、SSRF、权限绕过,但需一定上下文条件
  • medium:XSS、日志注入、信息泄露(如堆暴露路径)
  • 没有 cvssScore 字段;不要把 high 当作 CVSS 7.0+,也不要把 medium 当作可忽略
{
  "advisory": {
    "title": "Remote code execution in guzzlehttp/guzzle",
    "severity": "critical",
    "cve": "CVE-2023-38913",
    "link": "https://symfony.com/security/advisories/CVE-2023-38913"
  },
  "package": "guzzlehttp/guzzle",
  "version": "7.4.5"
}

为什么 composer audit 没报出已知漏洞(比如 laravel/framework

常见原因有三个,按优先级排查:

  • 你的 vendor/laravel/framework 实际版本是 10.12.0,但 composer.lock 中记录的 version 字段被手动修改过,audit 读取的是 lock 文件里的声明版本,不是 vendor 中的真实文件头
  • 项目使用了 replaceprovide 配置,导致 audit 认为该包已被替代(例如用 laravel-zero/framework 替代原生 Laravel,但未同步更新安全元数据)
  • Symfony DB 尚未收录该漏洞(尤其新爆的 CVE),此时需主动订阅 FriendsOfPHP/security-advisories 仓库,并用 composer audit --source=github(需 Composer 2.6+)临时接入

最稳妥的做法:定期运行 composer show --outdated + 手动查 CVE 数据库,audit 只作为第一道自动化防线,不是最终裁决。

相关专题

更多
PHP Symfony框架
PHP Symfony框架

本专题专注于PHP主流框架Symfony的学习与应用,系统讲解路由与控制器、依赖注入、ORM数据操作、模板引擎、表单与验证、安全认证及API开发等核心内容。通过企业管理系统、内容管理平台与电商后台等实战案例,帮助学员全面掌握Symfony在企业级应用开发中的实践技能。

78

2025.09.11

laravel组件介绍
laravel组件介绍

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

319

2024.04.09

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

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

277

2024.04.09

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

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

370

2024.04.09

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

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

371

2024.04.10

laravel入门教程
laravel入门教程

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

81

2025.08.05

laravel实战教程
laravel实战教程

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

64

2025.08.05

laravel面试题
laravel面试题

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

68

2025.08.05

c++空格相关教程合集
c++空格相关教程合集

本专题整合了c++空格相关教程,阅读专题下面的文章了解更多详细内容。

0

2026.01.23

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 9.2万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 10.4万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

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

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