Composer默认以非交互模式运行,避免阻塞自动化流程。处理需交互输入的脚本时,应通过添加--no-interaction参数、使用环境变量(如CI)控制行为或利用Composer的IOInterface安全输出,确保脚本兼容非交互环境,推荐优先设计支持非交互模式的脚本逻辑。

Composer 在处理需要交互式输入的脚本时,默认会跳过或自动选择非交互模式,以避免阻塞自动化流程。如果你在使用 Composer 执行某些命令(如 scripts 中定义的脚本)时遇到需要用户输入的情况,可以通过以下方式合理处理。
Composer 默认在非交互模式下运行,特别是在 CI/CD、部署脚本或使用 --no-interaction 参数时。这意味着任何试图从 stdin 读取用户输入的操作都会失败或被忽略。
常见需要交互的场景包括:
最推荐的方式是修改脚本本身,支持非交互模式。例如,通过命令行参数跳过确认:
// 示例:自定义脚本支持 -n 或 --no-interaction
if (!$input->getOption('no-interaction')) {
$confirm = $io->ask('继续执行吗?[y/N]', 'N');
if (!in_array(strtolower($confirm), ['y', 'yes'])) {
exit(0);
}
}
这样在 Composer 脚本中调用时可以安全跳过:
"scripts": {
"post-install-cmd": "php bin/my-script.php --no-interaction"
}
通过环境变量判断是否处于自动化环境,自动启用非交互模式:
if (getenv('COMPOSER_DEV') === '0' || getenv('CI')) {
// 自动执行,不提示
} else {
// 正常交互
}
在部署时设置环境变量即可:
COMPOSER_DEV=0 composer install
如果你开发的是 Composer 插件或自定义脚本,建议使用 Composer 提供的 IOInterface 进行交互:
$io = $composer->getIO();
if ($io->isInteractive()) {
$answer = $io->ask('是否继续?[y/N] ', false);
}
这样 Composer 能正确处理输入流,兼容不同运行环境。
基本上就这些。关键在于避免依赖阻塞性输入,优先设计可自动化执行的脚本逻辑。大多数情况下,通过添加命令行标志或检查环境变量就能解决问题。Composer 本身不提供“模拟输入”的机制,也不推荐这样做,保持脚本无感运行更符合最佳实践。
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号