当你运行 composer update 时,某些包被移除通常是因为:1. 包为间接依赖且无直接引用;2. 存在版本冲突或互斥规则;3. 未在 composer.json 的 require 中显式声明;4. 所依赖的上游包更新后删除了该包。Composer 为保持依赖一致性会自动清理无明确依赖的包,因此需确保所需包均通过 composer require 正式添加并存在于 require 列表中。

当你运行 composer update 时,Composer 会根据 composer.json 和 composer.lock 文件重新计算整个依赖树,并尝试安装满足所有约束的最新版本。有时候你会发现一些你“需要”的包被移除了,这通常不是 Composer 出错,而是由以下几个原因导致的:
首先Eclipse需要安装Maven的插件, 用MyEclipse安装Maven插件,建出的Maven项目有些问题。一是,发布tomcat的时候resources总是不会被发布到tomcat下;二是,把WEB-INF下的classes改到target下的classes,但是不知道为什么MyEclipse要么仍然在WEB-INF下生成class。要么真不在WEB-INF生成classes了但是发布tomcat的时候,class文件一个都不会给你发布过去,超级郁闷。但是使用Eclipse构建Maven项目后,
1. 包被标记为“可选”或间接依赖
你可能之前使用了某个包,但它并不是在require 中显式声明的。例如:
- 该包只是另一个包的依赖(即“传递性依赖”)。
- 你在项目中手动 require 过它,但后来删除了相关代码或配置,Composer 检测到它不再被任何地方引用。
2. 版本冲突或依赖不兼容
某些包之间存在版本限制。当你执行composer update,可能会因为以下情况导致某个包无法共存:
- 新版本的 A 包要求 PHP 8.1+,而你系统环境是 8.0,某些依赖因此不能安装。
- B 包升级后弃用了 C 包,或者与 D 包存在互斥版本规则(conflict)。
3. composer.json 中没有明确 require
最常见的原因是:你以为某个包是项目必需的,但在composer.json 的 require 列表里根本没写它。
- 比如你通过
composer require foo/bar安装过,但后来不小心删掉了那一行。 - 或者你是临时测试用的,忘记正式加入依赖列表。
4. 使用了 --with-dependencies 但上游包变更
如果你更新的是一个你自己 require 的包,而这个包的新版本修改了自己的依赖列表(比如去掉了对某工具包的依赖),那么那个工具包也会从你的项目中消失。如何避免重要包被误删?
-
确保关键包都在
require中:打开composer.json,确认你需要的包都列在"require": {}下。 - 使用
composer require vendor/package显式添加,而不是依赖自动引入。 - 定期检查
composer show输出,看看实际安装了哪些包。 - 如果某个包虽未直接调用但必须存在(如插件机制),可在注释中说明,或结合脚本检测其是否存在。
composer.json,就不会轻易丢失。









