Composer根据包的composer.json中bin字段声明的可执行文件路径,将其复制或符号链接到vendor/bin目录下;例如"bin": ["bin/my-command"]会生成vendor/bin/my-command;这些文件是带有Shebang的PHP脚本,需有可执行权限;只有明确在bin中定义的文件才会被安装,若包无此配置则不生成任何命令;全局安装时同理,目标为~/.composer/vendor/bin,需配置PATH才能直接调用。

Composer 根据你项目中安装的每个 Composer 包(package)的 bin 配置来决定在 vendor/bin 目录下生成哪些可执行文件。
1. 包的 composer.json 中的 bin 字段
每个 PHP 包可以在其composer.json 文件中定义一个 bin 字段,这个字段指定一个或多个可执行脚本的路径。例如:{
"bin": [
"bin/my-command",
"bin/another-tool"
]
}
当这个包被安装时,Composer 会把 bin/my-command 和 bin/another-tool 这两个文件复制或符号链接到项目的 vendor/bin 目录下。2. 可执行文件的实际内容
这些 bin 文件通常是 PHP 脚本,带有 Shebang(如#!/usr/bin/env php),并且具备可执行权限。Composer 不修改这些文件的内容,只是将其放置到 vendor/bin 下,以便你可以通过如下方式运行:php vendor/bin/my-command # 或直接(如果 PATH 已配置) my-command3. 为什么有些包没有生成文件?
只有明确在bin 字段中声明的文件才会被放到另外,某些包可能只提供库功能,不提供命令行工具,因此不会定义vendor/bin。如果一个包没有bin配置,即使它有脚本在bin/目录下也不会被自动复制。bin。4. 全局安装时的情况
当你使用composer global require时,同样的规则适用,只是目标目录变成了全局的vendor/bin(通常是~/.composer/vendor/bin),你需要将该路径加入系统PATH才能直接调用这些命令。基本上就这些。Composer 的行为是基于每个依赖包自己声明的
bin列表来决定生成哪些可执行文件。










