当运行 composer update 时包被移除,是因 Composer 根据依赖解析决定其不再需要或存在冲突。1. 包未在 composer.json 的 require 或 require-dev 中声明,且无其他依赖引用它;2. composer.lock 与 composer.json 不一致,导致临时安装的包被清理;3. 版本冲突使某些包被排除,Composer 选择兼容性更优的组合;4. 更新特定包时其依赖变更,导致原有依赖被废弃。应确保所有包正确声明、使用 composer require 安装、提交 lock 文件,并通过 composer why-not 和 show --tree 分析依赖。

当你运行 composer update 时,某些看似必要的包被移除,通常不是随机发生的,而是由 Composer 的依赖解析机制根据当前的 composer.json 和已安装状态做出的决定。下面是一些常见原因和应对方法。
Composer 只保留被项目或其他包明确依赖的库。如果你手动添加过某个包,但后来修改了 composer.json,移除了对该包的引用(无论是直接 require 还是通过其他依赖引入),composer update 就会将其卸载。
检查方式:
composer.json 中的 require 和 require-dev 是否还包含该包。composer depends 包名 查看谁在使用它。composer update 会根据 composer.json 重新计算整个依赖树,忽略 composer.lock 的旧状态。如果你之前通过 require 添加了包但没提交到 composer.json(比如手动改过 vendor),这些“临时”安装的包不会被保留。
正确做法:
composer require vendor/package 安装,确保写入 composer.json。vendor 目录中的内容。某些包可能因为版本冲突被替代。例如 A 包要求 B 包 v1,C 包要求 B 包 v2,如果无法共存,Composer 可能选择不安装 A 包来满足整体兼容性,从而“移除” A 包。
表现:
composer why-not 包名 版本 可查看为何未安装。如果你更新某个特定包(如 composer update foo/bar),默认也会更新它的依赖。如果新版本的 foo/bar 不再需要你原来依赖的某个组件,那个组件就可能被移除。
建议:
composer show --tree 看依赖关系树是否合理。确保:
composer.json 中声明。composer install 部署)。composer.json 和 composer.lock 到版本控制。composer require 流程。基本上就这些。Composer 移除包是因为它认为那些包“不需要”或“不兼容”。只要你的 composer.json 正确描述了需求,结果就是可靠的。
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号