您的位置:首页 >Composer怎么看装了哪些包_Composer show命令使用说明【入门】
发布于2026-04-30 阅读(0)
扫一扫,手机访问

想快速摸清一个项目到底装了哪些依赖?composer show 这个命令是首选。不过,它的默认输出相当“克制”,只给你最核心的信息。想要看到依赖树、自动加载配置或是远程仓库里的所有版本,那就得带上对应的“钥匙”——也就是不同的参数。
composer show(无参数)这个命令读的是 vendor/ 目录下的实际安装结果,不是 composer.json 里写的声明。所以它反映的是 lock 文件生效后的最终状态,比看配置文件更真实。
name、version、descriptionrequire-dev 里,又用了 --no-dev),就不会出现在列表中composer show log 不会匹配 monolog/monolog,必须写全名或至少前缀(如 composer show monolog)composer show | less 或 composer show | grep -i cachecomposer show -s类找不到、自定义命令不执行,八成是 autoload 映射或 scripts 没配对。-s(即 --show-config)能直接把这两块关键字段打出来,不用去翻源码或 composer.json。
composer show -s monolog/monolog 会显示 "Monolog\": "src/",说明 MonologLogger 对应 vendor/monolog/monolog/src/Logger.phpscripts 字段里注册的钩子,比如 post-install-cmd 是否包含 phpunitunrecognized 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.0composer.lock 里已确定的路径;如果某包只在 require-dev 且你用过 --no-dev,就不会出现composer show --tree | grep guzzle--tree 时,composer show vendor/package 只列顶层信息,看不到谁把它拉进来的composer show --all--all(双横线,不是 -a)会绕过本地缓存,直连 Packagist API,返回该包所有可用版本的摘要。这是装之前确认兼容性的关键一步。
composer show --all symfony/console 输出含版本号、发布时间、是否稳定、最低 PHP 版本要求composer.json;要看 v6.4.0 的 autoload 或 require,得写全:composer show symfony/console 6.4.0 -ssymfony/consoole)时默认静默失败;加 -v 才能看到 Package not foundrepositories 已配置在 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 install 或 composer update --lock 再试。
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9