跳到主要内容
版本:next

入门

此文档将帮助你了解如何构建你的第一个插件并在 Halo 中安装和启用。

创建插件项目

我们为插件开发者提供了一个插件创建工具,可以帮助你快速创建一个插件项目。

pnpm create halo-plugin
🚀 Welcome to Halo Plugin Creator!

✔ Plugin name: › hello-world
✔ Domain (for group and package name): › com.example
✔ Author name: › Halo
✔ Choose UI build tool: › Rsbuild

📋 Project Configuration:
Name: hello-world
Domain: com.example
Package: com.example.hello-world
Author: Halo
UI Tool: rsbuild
Output Directory: /path/to/hello-world

✔ Create project? › yes
  • Plugin name: 插件的名称,用于插件的标识,此字段必须由小写字母、数字和连字符组成
  • Domain: 插件的包名
  • Author name: 插件的作者
  • Choose UI build tool: 插件的 UI 构建工具,目前支持 RsbuildVite

更多关于插件创建工具的信息可查阅:halo-dev/create-halo-plugin

运行插件

现在有了一个空项目,我们需要让插件能最最小化的运行起来,这里提供两种运行方式。

使用 DevTools 运行(推荐)

Halo 提供了一个用于插件开发的 DevTools,它可以帮助你快速的运行和调试插件,在模板插件项目中已经集成了 DevTools,可查阅 DevTools 使用说明

使用 DevTools 运行插件的前提是需要你的电脑上已经安装了 Docker 环境,这是我们推荐的用户开发时运行插件的方式,只需要执行以下命令即可。

  1. 运行插件:

    # macOS / Linux
    ./gradlew haloServer

    # Windows
    ./gradlew.bat haloServer

    执行此命令后,会自动创建一个 Halo 的 Docker 容器并加载当前的插件。

  2. 启动成功后,可以看到如下日志输出:

    Halo 初始化成功,访问:http://localhost:8090/console
    用户名:admin
    密码:admin

    然后访问 http://localhost:8090/console

    在插件列表将能看到插件已经被正确启动,并且在左侧菜单添加了一个 示例分组,其下有一个名 示例页面 的菜单。

    hello-world-in-plugin-list

传统方式运行

如果你的设备上无法安装 Docker 或你对 Docker 不熟悉,可以使用传统方式运行并开发插件。

但由于此方式需要先使用源码运行 Halo 才能启动插件,请确保已经在开发环境运行了 Halo,可以参考 Halo 开发环境运行

  1. 编译插件

    # macOS / Linux
    ./gradlew build

    # Windows
    ./gradlew.bat build
  2. 修改 Halo 配置文件:

    # 进入 Halo 项目根目录后,使用 cd 命令进入配置文件目录
    cd application/src/main/resources

    # 创建 application-local.yaml 文件
    touch application-local.yaml

    根据你的操作系统,将以下内容添加到 application-local.yaml 文件中。

    # macOS / Linux
    halo:
    plugin:
    runtime-mode: development
    fixed-plugin-path:
    # 配置为插件项目目录绝对路径
    - /path/to/halo-plugin-hello-world

    # Windows
    halo:
    plugin:
    runtime-mode: development
    fixed-plugin-path:
    # 配置为插件项目目录绝对路径
    - C:\path\to\halo-plugin-hello-world
  3. 启动 Halo

    # macOS / Linux
    ./gradlew bootRun --args="--spring.profiles.active=dev,local"

    # Windows
    gradlew.bat bootRun --args="--spring.profiles.active=dev,win,local"

    然后访问 http://localhost:8090/console

    在插件列表将能看到插件已经被正确启动,并且在左侧菜单添加了一个 示例分组,其下有一个名 示例页面 的菜单。

    hello-world-in-plugin-list