0

0

composer怎么运行自定义Scripts_composer怎么配置命令行脚本【教程】

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-03-12 13:09:20

|

500人浏览过

|

来源于php中文网

原创

Composer scripts需显式调用或通过生命周期命令触发,非自动运行;键名分内置钩子(如post-install-cmd)和自定义命令,执行受--no-scripts、路径、权限、环境及递归调用影响。

composer怎么运行自定义scripts_composer怎么配置命令行脚本【教程】

scripts 里写的命令到底怎么执行

Composer 的 scripts 不是自动运行的,它只是注册了一组命名命令,必须显式调用才能触发。很多人写完 "post-install-cmd": "php build.php" 就以为装包时会自动跑,结果啥也没发生——因为默认不启用钩子执行,得加 --no-scripts 才会跳过,而默认其实是「允许」,但前提是:你得真去运行 composer installcomposer update 这类会触发生命周期的命令。

实操建议:

人民网AIGC-X
人民网AIGC-X

国内科研机构联合推出的AI生成内容检测工具

下载
  • 想手动执行某个 script,用 composer run-script <script-name></script-name>,比如 composer run-script post-install-cmd
  • 想让 install 自动触发 post-install-cmd,确保没加 --no-scripts 参数(CI 环境有时会默认加)
  • 脚本值如果是字符串,会被 shell 解析;如果是数组,会逐条执行(顺序敏感)
  • 路径问题很常见:脚本里用的相对路径,是以项目根目录(即 composer.json 所在位置)为基准,不是以当前 shell 工作目录为准

PHP 函数和 CLI 命令混写容易崩在哪

scripts 里直接写 "build": "php -r \"echo date();\"" 看似没问题,但引号嵌套、环境变量、输出重定向全会变脆弱。更典型的是误把 PHP 函数当命令用,比如写 "test": "var_dump(1)" —— 这根本不是 shell 命令,会报 sh: var_dump: not found

实操建议:

  • 纯 PHP 逻辑,优先写成独立文件 + php path/to/script.php,别塞内联代码
  • 需要传参?用 $argv 接收,不要依赖 $_SERVER['argv'],因为 composer run-script 会把 script 名也塞进参数里
  • 想调用自定义类或 Composer 自动加载?确保脚本文件顶部有 require __DIR__ . '/vendor/autoload.php';
  • Windows 下反斜杠、空格路径、PowerShell 和 cmd 行为差异大,测试务必在目标环境跑

scripts 键名不是随便起的,有些名字有特殊含义

Composer 识别一部分固定名称作为生命周期钩子,比如 pre-install-cmdpost-autoload-dump,它们会在特定时机自动执行;而像 buildlint 这种自定义名,只能靠 composer run-script build 显式调用。混淆这两类会导致“为什么我写了 pre-update-cmd 却没反应”——可能是因为你只跑了 composer install,而它只触发 install 相关钩子。

实操建议:

  • 查官方文档确认钩子触发时机,常用钩子包括:pre-install-cmdpost-install-cmdpre-update-cmdpost-update-cmdpost-autoload-dump
  • 自定义命令名避免和内置钩子重名,否则行为可能被覆盖或叠加
  • 钩子脚本失败(exit code ≠ 0)会导致整个 composer 命令中断,默认行为,不可跳过
  • 调试钩子是否触发?加一句 echo "RUNNING post-install-cmd" 到脚本开头,最直白

script 中调用其他 composer 命令要小心递归和上下文

post-install-cmd 里再写 composer dump-autoload 是常见操作,但要注意:这会重新读取 composer.json 并再次触发钩子——如果 dump-autoload 又触发了 post-autoload-dump,而后者又调用了别的 composer 命令……就可能形成隐式递归,尤其在 CI 上容易卡死或超时。

实操建议:

  • 避免在钩子里调用会再次触发同类钩子的命令,比如 composer installpost-install-cmd 里就是危险操作
  • 需要用 composer 命令时,加 --no-scripts 抑制二次触发,例如:composer dump-autoload --no-scripts
  • 钩子执行时的当前工作目录是项目根目录,但 COMPOSER_HOMECOMPOSER_VENDOR_DIR 等环境变量未必是你预期的值,别假设它们一定存在
  • 权限问题常被忽略:某些脚本生成文件后,后续命令因权限不足读不到,比如 phpunit 找不到缓存目录
脚本是否执行,不取决于它写在 scripts 里,而取决于你用什么命令触发、有没有禁用钩子、路径和权限是否匹配。最容易被忽略的是:钩子失败会中断整个流程,而错误输出可能被 composer 的进度条吞掉,得加 -v 或重定向看真实 exit code。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
composer是什么插件
composer是什么插件

Composer是一个PHP的依赖管理工具,它可以帮助开发者在PHP项目中管理和安装依赖的库文件。Composer通过一个中央化的存储库来管理所有的依赖库文件,这个存储库包含了各种可用的依赖库的信息和版本信息。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

161

2023.12.25

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

456

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

546

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

335

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

require的用法
require的用法

require的用法有引入模块、导入类或方法、执行特定任务。想了解更多require的相关内容,可以阅读本专题下面的文章。

510

2023.11.27

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

760

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
第二十四期_PHP8编程
第二十四期_PHP8编程

共86课时 | 3.5万人学习

成为PHP架构师-自制PHP框架
成为PHP架构师-自制PHP框架

共28课时 | 2.6万人学习

第二十三期_PHP编程
第二十三期_PHP编程

共93课时 | 7.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号