0

0

Composer conflict字段怎么写 定义包冲突规则说明【文档】

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-01-24 18:29:10

|

192人浏览过

|

来源于php中文网

原创

conflict 字段用于声明当前包与哪些其他包互斥,格式为键值对,键是包名(如 monolog/monolog),值是版本约束(如 ^2.0),安装或更新时若匹配则报错阻止。

composer conflict字段怎么写 定义包冲突规则说明【文档】

composer.json 里的 conflict 字段怎么写

conflictcomposer.json 中用于声明「当前包与哪些其他包互斥」的字段,不是用来解决冲突的工具,而是提前阻止 Composer 安装不兼容的依赖。它在安装或更新时触发错误,防止运行时出问题。

写法是键值对:键为包名(如 monolog/monolog),值为版本约束(如 ^2.0)。支持所有 Composer 版本运算符:>>=!=^~*

  • "conflict": { "php": " —— 禁止在 PHP 8.0 以下环境安装
  • "conflict": { "guzzlehttp/guzzle": ">=7.0 —— 冲突特定小版本区间
  • "conflict": { "laravel/framework": "*" } —— 完全禁止 Laravel(慎用)

什么时候该用 conflict,而不是 requirereplace

conflict 的核心场景是「已知不兼容,且无法通过代码适配」。比如你的包用了某个库的私有 API,在 v3.2+ 被移除,但 v3.1 又存在安全漏洞——这时不能靠 require 锁版本,而要用 conflict 明确排除危险范围。

WeShop唯象
WeShop唯象

WeShop唯象是国内首款AI商拍工具,专注电商产品图片的智能生成。

下载
  • require 表达「我需要什么」;用 conflict 表达「我绝不能和谁共存」
  • replace 是声明「我替代了谁」(如 fork 包),不影响安装逻辑;conflict 会直接中断 composer install
  • 若冲突只发生在特定扩展启用时(如 ext-redis vs ext-predis),conflict 无能为力,得靠运行时检测

常见错误:为什么写了 conflict 却没报错

最常被忽略的是作用域问题:conflict 只在当前包被安装(或作为依赖被拉入)时生效。如果用户项目里直接 require 了冲突包,而你的包没被加载(比如只是 dev-dependency),那根本不会触发检查。

  • 确保你的包实际出现在最终依赖图中(不是仅在 require-dev 里)
  • Composer 不会回溯检查已安装包是否违反新加入包的 conflict 规则——只有执行 composer update 或新 install 时才校验
  • "conflict": { "myorg/mylib": "dev-main" } 没用:分支名、dev- 前缀、alias 都不参与 conflict 匹配,只认稳定版本号

conflictplatform / platform-check 的关系

conflict 可以写 phpext-*lib-*,但这部分行为受 config.platform 影响。如果你在根项目设了 "platform": { "php": "8.1.0" },Composer 会假装运行在 PHP 8.1,导致 "conflict": { "php": " 失效——因为平台声明覆盖了真实环境判断。

  • 运行时 PHP 版本冲突,优先用 config.platform-check = true(默认开启),它会在 composer install 后额外校验真实环境
  • conflict 中的扩展名(如 ext-mbstring)必须拼写完全一致,大小写敏感,且不支持通配符
  • 想让 CI 环境也触发检查?确保没设 COMPOSER_DISABLE_PLATFORM_CHECKS=1
真正容易漏掉的是:冲突规则不会自动传播。A 包 conflict B,B 包 conflict C,不代表 A 和 C 自动互斥——每个包得各自声明。

相关专题

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

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

150

2023.12.25

json数据格式
json数据格式

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

417

2023.08.07

json是什么
json是什么

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

535

2023.08.23

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

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

311

2023.10.13

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

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

76

2025.09.10

c++ 根号
c++ 根号

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

17

2026.01.23

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

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

22

2026.01.23

yy漫画官方登录入口地址合集
yy漫画官方登录入口地址合集

本专题整合了yy漫画入口相关合集,阅读专题下面的文章了解更多详细内容。

91

2026.01.23

漫蛙最新入口地址汇总2026
漫蛙最新入口地址汇总2026

本专题整合了漫蛙最新入口地址大全,阅读专题下面的文章了解更多详细内容。

124

2026.01.23

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.5万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.2万人学习

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

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