首页 游戏 软件 资讯 排行榜 专题
首页
编程语言
Composer怎么查看已安装的所有包_Composer如何用show列出项目的依赖列表【命令】

Composer怎么查看已安装的所有包_Composer如何用show列出项目的依赖列表【命令】

热心网友
58
转载
2026-05-03

Composer怎么查看已安装的所有包_Composer如何用show列出项目的依赖列表【命令】

Composer怎么查看已安装的所有包_Composer如何用show列出项目的依赖列表【命令】

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

composer show 不加参数就能列出全部已安装包

其实,想快速摸清项目依赖的家底,最直接的办法就是运行 composer show。这个命令会立刻输出当前项目 vendor/ 目录下所有已安装的包,清清楚楚地列出包名、版本号和简短描述。它读取的数据源是 vendor/composer/installed.json(或者 installed.php),这比直接看 composer.lock 更贴近运行时实际加载的状态。

这里有个常见的理解偏差:很多人以为必须加上 -a--all 参数才能看到全部。其实恰恰相反,不加任何参数就是默认展示全量列表;而 --all 参数的作用,主要是为了把平台包(比如 ext-curlphp 本身)也一并包含进来。

  • 如果只想快速浏览包名和版本,可以用 composer show --name-only(要求 Composer 2.5+ 版本),或者在 Linux/macOS 下用管道处理:composer show | cut -d' ' -f1
  • 打算把列表导出为纯文本,方便后续用 grep 等工具处理?加上 --format=txt 参数会更稳妥(虽然它和默认格式基本等价)。
  • 需要警惕的是:如果项目从未执行过 composer installcomposer update,导致 vendor/ 目录是空的,那么运行 composer show 会直接报错 Could not find package

composer show vendor/name 查看单个包的详细信息

当你需要深入了解某个特定包时,比如想查看 monolog/monolog 的依赖树、源码仓库地址、自动加载配置或者所有可用版本,命令就变成了 composer show monolog/monolog。它会展示该包在本地实际安装的版本,并给出其 composer.json 元数据的一个快照。

值得注意的是,这个命令完全在本地运行,不联网,也不会查询 Packagist。它只读取已经安装在 vendor/ 里的包的元信息。所以,如果你刚刚用 composer require 添加了一个包,但还没执行 install,那么它是不会出现在查询结果里的。

  • 想看看某个包能升级到哪些版本?加上 --all 参数试试,例如 composer show monolog/monolog --all
  • 要判断一个包是项目直接依赖,还是被其他包间接引入的?可以查看输出中的 type 字段是否为 library,再结合项目根目录的 composer.json 文件里的 require 部分进行比对。
  • 如果遇到 Package not found 的提示,先别急。用 ls vendor/ 确认一下包目录是否存在,再仔细检查包名的大小写——Composer 的包名是严格区分大小写的,guzzlehttp/guzzleGuzzleHttp/Guzzle 会被视为两个不同的包。

composer show --tree 输出依赖关系树

想要理清“谁依赖了谁”这团乱麻?composer show --tree 是最直观的工具。它会从根项目开始,像展开一棵树一样,递归地展示每一层依赖关系,用缩进来清晰表示层级。这样一来,哪几个包共同引入了同一个子依赖(比如都依赖 psr/log)就一目了然了。

不过,它也有局限性:不会显示版本冲突或者未满足的版本约束。这类问题得靠 composer why-notcomposer prohibits 命令来诊断。另外,--tree 默认只展示运行时依赖(即 require 部分),不包括开发依赖(require-dev),除非你显式加上 --dev 参数。

  • 只想看开发依赖的树状结构?用 composer show --tree --dev
  • 想从庞大的依赖树中过滤出特定类型的包,比如所有 symfony/* 系列的?可以配合管道和 grep 命令:composer show --tree | grep "symfony/"
  • 这里有个容易踩坑的细节:如果某个包被项目中的多条依赖路径同时引入,--tree 命令默认只展示第一条路径,不会标记出重复引用的情况。所以,别用它来准确判断依赖的收敛效果。

composer show 和 composer depends 的关键区别

这是很多开发者容易混淆的地方。简单来说,composer show package/name 回答的是“这个包自己长什么样”,而 composer depends package/name 回答的是“谁在用它”。后者才是当你考虑是否要移除某个包时,用来判断“会不会影响其他组件”的关键命令。

举个例子,你想确认 doctrine/annotations 这个包是不是只有 doctrine/orm 在用,还是你自己的业务代码也直接 use 了它。这时候就该用 composer depends doctrine/annotations。它会列出所有直接依赖它的包,包括根项目本身(会显示为 root)。

  • 加上 --recursive 参数,可以看到间接依赖它的包(也就是“依赖的依赖”),但输出可能会非常冗长,使用时要谨慎。
  • depends 命令只列出包名,不显示具体的版本号。要查版本,还得回头用 show 命令或者去翻 composer.lock 文件。
  • 一个常被忽略的细节:depends 默认不会包含 require-dev 中的依赖,除非你显式加上 --dev 参数。否则,你可能会漏掉测试工具链里的调用关系。

话说回来,真正关键的不是死记硬背这几个命令,而是理解它们背后的逻辑:show 系列命令始终基于 vendor/ 目录下的已安装状态;而 dependsprohibits 这类命令,依赖的则是 composer.json 文件中声明的依赖关系逻辑。当这两者给出的信息不一致时,往往意味着 composer.lock 文件已经过期,或者有人手动改动过 vendor/ 目录里的内容了。

来源:https://www.php.cn/faq/2329758.html
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

相关攻略

Composer如何安装Mockery Mock库_Composer安装Mockery Mock库要点
编程语言
Composer如何安装Mockery Mock库_Composer安装Mockery Mock库要点

Composer安装Mockery Mock库要点 直接运行 composer require --dev mockery mockery 就能装好,但装完报 “Class Mockery not found” 是最常踩的坑,问题几乎都不出在安装本身。 为什么 composer require

热心网友
05.03
Composer如何快速定位 vendor 中的源码位置_利用 IDE 插件跳转【开发技巧】
编程语言
Composer如何快速定位 vendor 中的源码位置_利用 IDE 插件跳转【开发技巧】

Composer如何快速定位 vendor 中的源码位置_利用 IDE 插件跳转【开发技巧】 遇到IDE的“跳转到定义”在vendor目录里失灵,先别急着怀疑工具。这事儿十有八九,问题出在autoload的映射关系上——要么是映射文件压根没更新,要么是路径对不上号。你得先让Composer把类和文件

热心网友
05.03
Composer解决由于composer命令冲突报错_修改全局alias别名【系统设置】
编程语言
Composer解决由于composer命令冲突报错_修改全局alias别名【系统设置】

根本问题是PATH中多个composer文件冲突,系统优先执行了损坏或版本不匹配的旧文件(如OpenServer中的composer bat);应将官方路径C: ProgramData ComposerSetup bin移至PATH最前,而非删除旧条目,并验证where composer首行、com

热心网友
05.03
如何在Composer中管理生产环境的依赖锁定
编程语言
如何在Composer中管理生产环境的依赖锁定

生产环境必须使用 composer install 并严格依赖已提交的 composer lock 文件,禁用 composer update;需强制 --no-dev、验证 lock 一致性、适配 PHP 版本变更。 在生产环境中,依赖版本必须被锁定。这背后的逻辑很简单:如果不用锁定的版本,com

热心网友
05.03
老项目还在用Composer1.x?一键升级Composer2享受数倍性能提升
编程语言
老项目还在用Composer1.x?一键升级Composer2享受数倍性能提升

老项目还在用Composer1 x?一键升级Composer2享受数倍性能提升 直接升级到 Composer 2 x 版本,这条路是安全且被官方推荐的。但先别急着点下确认键,有个前提必须厘清:项目的依赖兼容性。尤其是当 composer lock 文件被重新生成后,那些藏在 require-dev

热心网友
05.03

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

如何在Composer中配置自动更新周期
编程语言
如何在Composer中配置自动更新周期

如何在Composer中配置自动更新周期 开门见山地说,Composer本身并不提供所谓的“自动更新周期”配置功能。 它没有内置任何定时检查或自动执行 composer update 的机制。所有你看到的关于设置自动更新的讨论,本质上都是通过外部调度工具(比如cron或者GitHub Actions

热心网友
05.03
VSCode如何部署应用到云平台_VSCode部署应用到云平台要点
编程语言
VSCode如何部署应用到云平台_VSCode部署应用到云平台要点

VSCode部署依赖插件和CLI工具,90%失败因本地CLI未安装、未登录或项目结构不符;Azure需Azure Account与Azure App Service双扩展并重启;Heroku需正确安装CLI、登录并配置Procfile;部署前须检查端口监听、启动文件及环境变量。 很多开发者习惯在VS

热心网友
05.03
VSCode配置PowerShell环境_Windows脚本编写效率提升方案
编程语言
VSCode配置PowerShell环境_Windows脚本编写效率提升方案

VSCode 能真正运行并调试 PowerShell 脚本的关键在于三步 想让 VSCode 顺畅地跑起 PowerShell 脚本,还能愉快地打断点调试?很多人第一步就错了——关键不在于你装没装那个 PowerShell 扩展,而在于背后三个环环相扣的配置:pwsh exe 或 powershel

热心网友
05.03
iOS币安交易平台APP下载v3.0.5 苹果手机安装币安APP详细步骤
web3.0
iOS币安交易平台APP下载v3.0.5 苹果手机安装币安APP详细步骤

iOS币安交易平台APP下载v3 0 5 苹果手机安装币安APP详细步骤 想在iPhone上使用币安进行交易,其实并不复杂。整个过程可以概括为几个核心步骤:首先通过币安官网下载iOS版APP;点击安装后等待应用图标出现在桌面;首次打开时若提示“未受信任的企业级开发者”,需进入“设置-通用-翻跟斗与设

热心网友
05.03
小米净水器滤芯能清洗吗
电脑教程
小米净水器滤芯能清洗吗

净水器滤芯到底能不能清洗?揭秘常见使用误区与正确保养方法 许多小米净水器用户都曾有过这样的疑问:机器内部的滤芯是否可以拆解清洗,以延长使用寿命、节省更换成本?这里需要明确一个核心原则:净水器的核心过滤元件不支持用户自行拆解清洗,但整机系统确实配备了科学的自动冲洗与清洁程序,以维持其最佳性能。 从产品

热心网友
05.03