游乐游手机版
首页/编程语言/文章详情

Composer怎么看装了哪些包_Composer show命令使用说明【入门】

时间:2026-05-04 08:35
直接运行 composer show 就能列出当前项目所有已安装的包,但默认只显示包名、版本号和一行简短描述——它不自动展开 autoload、依赖树或远程版本,这些都得靠参数显式触发。 想快速摸清一个项目到底装了哪些依赖?composer show 这个命令是首选。不过,它的默认输出相当“克制”,

直接运行 composer show 就能列出当前项目所有已安装的包,但默认只显示包名、版本号和一行简短描述——它不自动展开 autoload、依赖树或远程版本,这些都得靠参数显式触发。

Composer怎么看装了哪些包_Composer show命令使用说明【入门】

想快速摸清一个项目到底装了哪些依赖?composer show 这个命令是首选。不过,它的默认输出相当“克制”,只给你最核心的信息。想要看到依赖树、自动加载配置或是远程仓库里的所有版本,那就得带上对应的“钥匙”——也就是不同的参数。

查当前项目装了哪些包:composer show(无参数)

这个命令读的是 vendor/ 目录下的实际安装结果,不是 composer.json 里写的声明。所以它反映的是 lock 文件生效后的最终状态,比看配置文件更真实。

  • 输出是表格形式,含三列:nameversiondescription
  • 如果包没被真正安装(比如只在 require-dev 里,又用了 --no-dev),就不会出现在列表中
  • 不支持模糊搜索;输 composer show log 不会匹配 monolog/monolog,必须写全名或至少前缀(如 composer show monolog
  • 输出太长时别硬翻,加管道:composer show | lesscomposer show | grep -i cache

查某个包的 autoload 和 scripts 配置:composer show -s

类找不到、自定义命令不执行,八成是 autoload 映射或 scripts 没配对。-s(即 --show-config)能直接把这两块关键字段打出来,不用去翻源码或 composer.json

  • composer show -s monolog/monolog 会显示 "Monolog\": "src/",说明 MonologLogger 对应 vendor/monolog/monolog/src/Logger.php
  • 也会列出 scripts 字段里注册的钩子,比如 post-install-cmd 是否包含 phpunit
  • 这个选项在 Composer 2.2+ 才稳定支持;旧版本会报 unrecognized option,别试
  • 不加 -s 时,默认只输出一行:monolog/monolog 3.5.0,容易误以为“查不到详情”

查某个包为什么装了两个版本:composer show --tree

依赖冲突最直观的证据就藏在依赖树里。--tree 不是展示你写了什么,而是还原 Composer 实际解析出的安装路径——这才是排查 “为什么 psr/log 装了 v2 和 v3” 的唯一可靠方式。

  • 输出是缩进结构,例如:lara vel/framework v10.48.12 └── symfony/console v6.4.7 └── psr/log 3.0.0
  • 它只展示 composer.lock 里已确定的路径;如果某包只在 require-dev 且你用过 --no-dev,就不会出现
  • 想快速定位某依赖,直接管道过滤:composer show --tree | grep guzzle
  • 注意:不加 --tree 时,composer show vendor/package 只列顶层信息,看不到谁把它拉进来的

查远程包有没有新版本、支不支持 PHP 8.3:composer show --all

--all(双横线,不是 -a)会绕过本地缓存,直连 Packagist API,返回该包所有可用版本的摘要。这是装之前确认兼容性的关键一步。

  • composer show --all symfony/console 输出含版本号、发布时间、是否稳定、最低 PHP 版本要求
  • 它不显示某个具体版本的完整 composer.json;要看 v6.4.0 的 autoloadrequire,得写全:composer show symfony/console 6.4.0 -s
  • 包名拼错(如 symfony/consoole)时默认静默失败;加 -v 才能看到 Package not found
  • 私有包要查到,得先确保 repositories 已配置在 composer.json 中,或临时指定:composer show --repository https://your-satis.example.com/packages.json myorg/private-lib

最容易被忽略的是:所有 composer show 命令都必须在项目根目录(有 composer.json 的地方)执行,且严重依赖 composer.lock 的完整性。lock 文件损坏或缺失时,--tree-s 可能返回空或错误结果,这时候先 composer installcomposer update --lock 再试。

来源:https://www.php.cn/faq/2349204.html
上一篇Composer怎么迁移依赖到新项目_Composer依赖迁移操作步骤【实用】 下一篇Composer怎么安装Flysystem文件系统_Composer如何引入Flysystem做文件存储抽象层【教程】
本站内容用于信息整理与展示,如有侵权或内容问题请及时联系处理。

相关推荐

补充同频道和同主题内容,方便继续浏览更多相关内容。

同类最新

继续查看同栏目最近更新的文章。

更多
CentOS与Golang打包常见兼容性问题探讨
编程语言 · 2026-07-01

CentOS与Golang打包常见兼容性问题探讨

CentOS与Golang打包的兼容性问题集中在glibc版本不匹配、交叉编译环境变量错误、依赖库缺失及Go依赖管理不规范。可通过Docker容器编译、选择兼容Go版本、正确设置GOOS GOARCH环境变量、安装对应开发包及使用GoModules解决。

CentOS中Fortran与Python如何协同工作从入门到实战完整教程
编程语言 · 2026-07-01

CentOS中Fortran与Python如何协同工作从入门到实战完整教程

在CentOS中,Fortran与Python可通过f2py、SWIG、共享库调用或subprocess协同。f2py封装Fortran为Python模块,支持数组运算;共享库需手动对齐数据类型;系统调用适合独立计算。

CentOS中Golang打包优化方法
编程语言 · 2026-07-01

CentOS中Golang打包优化方法

在CentOS中优化Golang编译打包,可显著提升编译速度并减小二进制文件体积。关键技巧包括:设置环境变量、使用Go模块管理依赖、编译时添加-ldflags= "-s-w "去除调试信息、利用UPX工具压缩、运行strip清理符号表,以及优化cgo内C代码的编译选项。综合运用这些方法能有效优化最终程序。

在CentOS系统中cpustat与其他工具协同使用的完整方法
编程语言 · 2026-07-01

在CentOS系统中cpustat与其他工具协同使用的完整方法

cpustat作为sysstat包的CPU监控工具,可通过管道与grep等命令配合过滤数据,利用脚本自动记录带时间戳的日志,或结合图形工具查看,也可格式化输出后接入Zabbix、Grafana等Web监控系统,实现可视化与告警。

CentOS中readdir与其他Linux发行版的差异
编程语言 · 2026-07-01

CentOS中readdir与其他Linux发行版的差异

CentOS基于RHEL,与Ubuntu、Debian、Fedora在包管理器(yum dnfvsapt)、默认文件系统(XFSvsext4)等存在差异,但readdir等系统调用遵循POSIX标准,行为一致。