0

0

Composer run-script怎么用_Composer执行自定义脚本教程【自动化】

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-03-02 15:30:12

|

198人浏览过

|

来源于php中文网

原创

composer run-script 仅执行 composer.json 中 "scripts" 下严格定义的脚本名,不支持模糊匹配或自动补全;参数传递需用 -- 分隔,且脚本执行时 cwd 为 composer.json 所在目录。

composer run-script怎么用_composer执行自定义脚本教程【自动化】

直接说结论: composer run-script 不是执行任意命令的快捷方式,它只调用 composer.json"scripts" 下定义的脚本名——拼错、没定义、没加引号,全都会报错或静默失败。

脚本名必须严格匹配 composer.json 中的键

Composer 不会模糊匹配,也不会自动补全。比如你写了 "scripts": { "dev-start": "php -S localhost:8000" },那必须用 composer run-script dev-start,写成 composer run-script dev_startcomposer run-script start 都会提示 Script not found

常见错误现象:Script not found: dev-start(但明明写了)——大概率是大小写不一致、多空格、用了中文标点,或者脚本名在 composer.json 里被意外注释掉了。

  • 检查是否用了双引号包裹脚本名:composer run-script "dev-start"(Windows 命令行尤其需要)
  • 确认 composer.json"scripts" 是顶层字段,没缩进到 "require" 或其他块里
  • 运行 composer run-script --list 查看当前可用脚本,这是最可靠的验证方式

run-script 的参数传递规则很反直觉

想传参给脚本?不能直接跟在后面写 composer run-script test -- --filter=FooTest。中间那个 -- 是分隔符,前面是 Composer 自己的选项,后面才是传给脚本的参数。

Favird No-Code Tools
Favird No-Code Tools

无代码工具的聚合器

下载

使用场景:跑 PHPUnit 时过滤测试用例、传环境变量给部署脚本。

  • 正确写法:composer run-script test -- --filter=FooTest
  • 错误写法:composer run-script test --filter=FooTest(这个 --filter 会被 Composer 当作自己的参数,报错或忽略)
  • 如果脚本本身是 shell 命令,注意引号嵌套:比如 "php test.php \"--verbose\"",否则空格和特殊字符会断开

别把 run-script 当成 npm run 的平替

Composer 脚本默认不继承当前 shell 环境变量(比如 $PATH),也不自动加载项目根目录下的 .env。很多“本地能跑、CI 报 command not found”的问题都出在这儿。

性能 / 兼容性影响:脚本每次执行都会重新加载 Composer 的 autoloader,频繁调用低效脚本(比如重复 composer dump-autoload)会明显拖慢流程。

  • 路径相关命令务必用相对路径:写 "./vendor/bin/phpunit",别写 "phpunit"(除非你确定 CI 环境 PATH 已配好)
  • 需要环境变量?显式导出:"export APP_ENV=testing && php artisan test",或改用 phpdotenv 在脚本里加载
  • 避免在脚本里反复执行 composer install —— 它不是轻量操作,应由 CI 流程统一管控

真正容易被忽略的是:脚本执行时的当前工作目录(CWD)是 composer.json 所在目录,不是你运行命令时所在的子目录。如果你在 ./tests 下执行 composer run-script test,脚本里的 ./src 依然从项目根开始算——这点和 npm 行为一致,但很多人调试时会下意识切错路径。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能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数据格式相关文章,帮助大家解决问题。

450

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的详细内容,可以访问本专题下面的文章。

326

2023.10.13

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

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

81

2025.09.10

require的用法
require的用法

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

506

2023.11.27

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

1356

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1159

2023.07.27

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

45

2026.02.28

热门下载

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

精品课程

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

共86课时 | 3.5万人学习

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

共28课时 | 2.6万人学习

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

共93课时 | 7.4万人学习

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

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