最推荐通过事件对象获取项目根目录:利用 Event 对象的 $event->getComposer() 获取实例,结合 vendor-dir 配置反推根路径,如 $composer->getConfig()->get('vendor-dir') . '/..' 并用 realpath 解析,确保稳定可靠且无需外部依赖。

在 Composer 脚本中获取当前项目的根目录,最可靠的方式是通过 $composer->getInstallationManager()->getInstallPath() 或直接利用 Composer 提供的事件对象来访问项目路径。但更常见和推荐的做法是使用 Composer 的 event 对象中的相关属性。
当你定义一个自定义脚本(如 post-install-cmd),Composer 会传入一个 ScriptEvent 对象。你可以从这个对象中获取 Composer 实例,并进一步获取项目根目录。
示例:自定义脚本类
use Composer\Script\Event;
use Composer\Util\Filesystem;
class BuildScript
{
public static function postInstall(Event $event)
{
$composer = $event->getComposer();
// 获取项目根目录(即 composer.json 所在的目录)
$projectDir = $composer->getConfig()->get('vendor-dir') . '/..';
$projectDir = realpath($projectDir);
echo "项目根目录: " . $projectDir . PHP_EOL;
// 或者使用 Filesystem 工具规范化路径
$fs = new Filesystem();
$projectDir = $fs->normalizePath($projectDir);
// 开始你的操作,比如复制文件、生成配置等
}
}确保你在 composer.json 中正确引用了该脚本:
{
"scripts": {
"post-install-cmd": "BuildScript::postInstall"
}
}Composer 默认将依赖安装在 vendor 目录下。因此,你也可以通过 __DIR__ 回退一级来获取项目根目录,尤其是在脚本位于 vendor/bin 或自定义命令中时:
$rootDir = dirname(__DIR__, 2); // 从 vendor/bin/your-script.php 出发,回退两级 // 或者更明确地: $rootDir = __DIR__ . '/../../'; // 相对 vendor/bin $rootDir = realpath($rootDir);
这种方法简单,但只适用于特定位置的脚本(如 bin 目录下的命令行工具)。
如果脚本环境复杂,也可以借助 Git 或 pwd 命令获取当前工作目录:
use Symfony\Component\Process\Process;
$process = Process::fromShellCommandline('pwd');
$process->run();
$rootDir = rtrim($process->getOutput(), "\n");注意:这依赖于执行脚本时的工作目录是否为项目根目录,适合 CLI 工具场景。
基本上就这些方法。最推荐的是通过 event->getComposer() 配合 vendor 目录反推,既稳定又无需外部依赖。
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号