×

Composer 中文文档

Composer 简介Composer 基本用法Composer 库(资源包)Composer 命令行Composer 架构Composer 资源库

Composer 相关文章

Composer 使用别名Composer 自定义安装程序Composer 插件Composer 脚本Composer Vendor BinariesComposer PHP依赖管理

Composer 常见问题

如何自定义一个资源包安装目录我应该提交 vendor 目录中的依赖包吗?为什么说“比较符”和“通配符”相结合的版本约束是坏主意?为什么不递归加载储存库?

Composer 脚本


什么是脚本?

一个脚本,在 Composer 中,可以是一个 PHP 回调(定义为静态方法)或任何命令行可执行的命令。脚本对于在 Composer 运行过程中,执行一个资源包的自定义代码或包专用命令是非常有用的。

注意:只有在根包的 composer.json 中定义的脚本才会被执行。即便根包的外部依赖定义了其自身的脚本,Composer 也不会去执行这些额外的脚本。

事件名称

Composer 在运行过程中将会触发以下事件:

事件名称 详细说明
**pre-install-cmd** 在 `install` 命令执行前触发。
**post-install-cmd** 在 `install` 命令执行后触发。
**pre-update-cmd** 在 `update` 命令执行前触发。
**post-update-cmd** 在 `update` 命令执行后触发。
**pre-status-cmd** 在 `status` 命令执行前触发。
**post-status-cmd** 在 `status` 命令执行后触发。
**pre-package-install** 在资源包安装前触发。
**post-package-install** 在资源包安装后触发。
**pre-package-update** 在资源包更新前触发。
**post-package-update** 在资源包更新后触发。
**pre-package-uninstall** 在资源包被卸载前触发。
**post-package-uninstall** 在资源包被卸载后触发。
**pre-autoload-dump** 在自动加载器被转储前触发,无论是 `install`/`update` 还是 `dump-autoload` 命令都会触发。
**post-autoload-dump** 在自动加载器被转储后触发,无论是 `install`/`update` 还是 `dump-autoload` 命令都会触发。
**post-root-package-install** 在 `create-project` 命令期间,根包安装完成后触发。
**post-create-project-cmd** 在 `create-project` 命令执行后触发。
  • pre-archive-cmd: occurs before the archive command is executed.
  • post-archive-cmd: occurs after the archive command is executed.

    注意:Composer 不会去执行任何依赖包中定义的 installupdate 相关脚本。因此你不应该在依赖包中申明 pre-update-cmdpre-install-cmd。如果你需要在执行 installupdate 命令前使用脚本,请确保它们已被定义在根包中。

定义脚本

composer.json 的根 JSON 对象中应该有一个名为 "scripts" 的属性,它包含有一系列的事件名称,以及对应的事件脚本。一个事件的脚本可以被定义为一个字符串(仅适用于单个脚本)或数组(单个或多个脚本)。

对于任何给定的事件:

  • 脚本将按照事件和定义的顺序触发。
  • 一个脚本数组可以包含 PHP 回调和命令行可执行命令。
  • 由 PHP 类文件包含的回调,其存放的位置必须确保 Composer 能够正确的载入。

脚本定义实例:

{
    "scripts": {
        "post-update-cmd": "MyVendor\MyClass::postUpdate",
        "post-package-install": [
            "MyVendor\MyClass::postPackageInstall"
        ],
        "post-install-cmd": [
            "MyVendor\MyClass::warmCache",
            "phpunit -c app/"
        ]
    }
}

使用前面定义的例子,这里的 MyVendorMyClass 类,就可以被使用来执行 PHP 的回调:



namespace MyVendor;

use ComposerScriptEvent;

class MyClass
{
    public static function postUpdate(Event $event)
    {
        $composer = $event->getComposer();
        // do stuff
    }

    public static function postPackageInstall(Event $event)
    {
        $installedPackage = $event->getOperation()->getPackage();
        // do stuff
    }

    public static function warmCache(Event $event)
    {
        // make cache toasty
    }
}

当一个事件被触发,Composer 的内部事件处理程序将接收一个 ComposerScriptEvent 对象,这是传递给您的 PHP 回调的第一个参数。这个 Event 对象拥有一些 getter 方法来帮助你取得当前事件的上下文:

  • getComposer(): 返回当前的 ComposerComposer 对象实例。
  • getName(): 返回事件名称的字符串。
  • getIO(): 返回当前的 输入输出 流,它实现了 ComposerIOIOInterface 接口,以便在控制台中使用。

手动运行脚本

如果你想手动运行事件脚本,可以使用下面的语法结构:

composer run-script [--dev] [--no-dev] script

例如 composer run-script post-install-cmd 将会运行所有 post-install-cmd 事件下定义的脚本。


分类导航

关注微信下载离线手册

bootwiki移动版 bootwiki
(群号:472910771)