0

0

Composer怎么配置脚本 Composer怎么自动执行命令【脚本】

穿越時空

穿越時空

发布时间:2026-03-03 14:23:34

|

850人浏览过

|

来源于php中文网

原创

composer怎么配置脚本 composer怎么自动执行命令【脚本】

scripts 里写的命令为什么没执行

Composer 的 scripts 不是写完就自动跑的,它只在你明确触发时才生效——比如运行 composer installcomposer update,或手动调用 composer run-script xxx。很多人以为加进 composer.json 就“一劳永逸”,结果部署后脚本静默失效。

  • 默认只有 post-install-cmdpost-update-cmd 这类带 post-/pre- 前缀的钩子才会自动触发;普通脚本名(如 "build": "npm run build")必须手动运行 composer run-script build
  • 如果用了 --no-scripts(CI 环境常见),所有脚本都会被跳过,连 post-* 钩子也不执行
  • 脚本运行路径是项目根目录,但当前工作目录(getcwd())可能不是——尤其在 symlink 或 Docker 挂载场景下,./bin/build.sh 可能找不到

怎么让 Composer 在 install/update 时自动跑自定义命令

post-install-cmdpost-update-cmd 这两个标准钩子。它们是 Composer 内置识别的 key,不是随便起个名就能自动触发的。

  • composer.jsonscripts 字段下,直接写:
    "scripts": {
      "post-install-cmd": ["@php artisan optimize:clear", "npm ci --silent"],
      "post-update-cmd": ["@php artisan migrate --force"]
    }
  • 注意:数组里每项都是独立命令,顺序执行;用 @xxx 可复用其他脚本(如 @php 会调用同文件中定义的 php 脚本)
  • 如果命令依赖扩展(比如 php 要用 mbstring),而当前 PHP CLI 环境没启用,脚本会直接报错退出,且不中断主流程(除非加 --no-dev 或配置了 COMPOSER_NO_INTERACTION=1

PHP 脚本 vs shell 命令:该选哪个写进 scripts

优先写 PHP 脚本,尤其是涉及逻辑判断、环境检测或 Composer 自身 API 调用时。Shell 命令看着快,但跨平台和错误处理极弱。

Pebblely
Pebblely

AI产品图精美背景添加

下载
  • PHP 脚本可读取 Composer\Script\Event 对象,拿到当前命令、IO、composer 实例等上下文,比如判断是不是在 CI 上:$event->isDevMode()
  • Shell 命令在 Windows 下容易崩(rm -rf$(pwd) 不兼容),而 php clean.php 一行就搞定
  • 别在 scripts 里写长 shell 链式调用(如 git status | grep -q 'dirty' && exit 1),出错时只报 “Script xxx returned with error code 1”,根本看不出哪步挂了

本地开发和 CI 环境下 scripts 表现不一致

核心差异在 PHP 版本、扩展、PATH 和用户权限。同一个 post-install-cmd 在本地成功,在 GitHub Actions 却卡住,大概率是环境假设错了。

  • CI 默认用最小化 PHP(常缺 opensslcurl),而你的脚本里用了 file_get_contents('https://...'),就会超时失败
  • composer install --no-dev 时,require-dev 里的包不可用,但脚本仍会执行——如果脚本里调用了 phpunit,就会报 command not found
  • 某些命令(如 chmod +x bin/*)在 macOS/Linux 正常,在 Windows Git Bash 下可能静默失败,且不报错

真正难搞的不是语法,是脚本执行时的隐式上下文:PHP 配置、扩展状态、文件权限、网络策略、甚至终端是否支持 ANSI 颜色——这些都不会出现在 composer.json 里,但每一项都可能让脚本在某个环境里突然哑火。

热门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数据格式相关文章,帮助大家解决问题。

452

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

328

2023.10.13

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

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

81

2025.09.10

require的用法
require的用法

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

506

2023.11.27

curl_exec
curl_exec

curl_exec函数是PHP cURL函数列表中的一种,它的功能是执行一个cURL会话。给大家总结了一下php curl_exec函数的一些用法实例,这个函数应该在初始化一个cURL会话并且全部的选项都被设置后被调用。他的返回值成功时返回TRUE, 或者在失败时返回FALSE。

454

2023.06.14

linux常见下载安装工具
linux常见下载安装工具

linux常见下载安装工具有APT、YUM、DNF、Snapcraft、Flatpak、AppImage、Wget、Curl等。想了解更多linux常见下载安装工具相关内容,可以阅读本专题下面的文章。

183

2023.10.30

Swift iOS架构设计与MVVM模式实战
Swift iOS架构设计与MVVM模式实战

本专题聚焦 Swift 在 iOS 应用架构设计中的实践,系统讲解 MVVM 模式的核心思想、数据绑定机制、模块拆分策略以及组件化开发方法。内容涵盖网络层封装、状态管理、依赖注入与性能优化技巧。通过完整项目案例,帮助开发者构建结构清晰、可维护性强的 iOS 应用架构体系。

3

2026.03.03

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
第二十四期_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号