mirror of
https://github.com/halo-dev/docs.git
synced 2026-01-14 07:02:53 +08:00
139 lines
4.1 KiB
Markdown
139 lines
4.1 KiB
Markdown
---
|
||
title: 入门
|
||
description: 了解如何构建你的第一个插件并在 Halo 中使用它。
|
||
---
|
||
|
||
此文档将帮助你了解如何构建你的第一个插件并在 Halo 中安装和启用。
|
||
|
||
## 创建插件项目
|
||
|
||
我们为插件开发者提供了一个插件创建工具,可以帮助你快速创建一个插件项目。
|
||
|
||
```bash
|
||
pnpm create halo-plugin
|
||
```
|
||
|
||
```bash
|
||
🚀 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 构建工具,目前支持 `Rsbuild` 和 `Vite`
|
||
|
||
更多关于插件创建工具的信息可查阅:[halo-dev/create-halo-plugin](https://github.com/halo-dev/create-halo-plugin)
|
||
|
||
## 运行插件
|
||
|
||
现在有了一个空项目,我们需要让插件能最最小化的运行起来,这里提供两种运行方式。
|
||
|
||
### 使用 DevTools 运行(推荐){#run-with-devtools}
|
||
|
||
Halo 提供了一个用于插件开发的 DevTools,它可以帮助你快速的运行和调试插件,在模板插件项目中已经集成了 DevTools,可查阅 [DevTools 使用说明](./basics/devtools.md)。
|
||
|
||
使用 DevTools 运行插件的前提是需要你的电脑上已经安装了 Docker 环境,这是我们推荐的用户开发时运行插件的方式,只需要执行以下命令即可。
|
||
|
||
1. 运行插件:
|
||
|
||
```shell
|
||
# macOS / Linux
|
||
./gradlew haloServer
|
||
|
||
# Windows
|
||
./gradlew.bat haloServer
|
||
```
|
||
|
||
执行此命令后,会自动创建一个 Halo 的 Docker 容器并加载当前的插件。
|
||
|
||
2. 启动成功后,可以看到如下日志输出:
|
||
|
||
```shell
|
||
Halo 初始化成功,访问:http://localhost:8090/console
|
||
用户名:admin
|
||
密码:admin
|
||
```
|
||
|
||
然后访问 `http://localhost:8090/console`
|
||
|
||
在插件列表将能看到插件已经被正确启动,并且在左侧菜单添加了一个 `示例分组`,其下有一个名 `示例页面` 的菜单。
|
||
|
||

|
||
|
||
### 传统方式运行 {#run-with-traditional-way}
|
||
|
||
如果你的设备上无法安装 Docker 或你对 Docker 不熟悉,可以使用传统方式运行并开发插件。
|
||
|
||
但由于此方式需要先使用源码运行 Halo 才能启动插件,请确保已经在开发环境运行了 Halo,可以参考 [Halo 开发环境运行](../core/run.md)
|
||
|
||
1. 编译插件
|
||
|
||
```shell
|
||
# macOS / Linux
|
||
./gradlew build
|
||
|
||
# Windows
|
||
./gradlew.bat build
|
||
```
|
||
|
||
2. 修改 Halo 配置文件:
|
||
|
||
```shell
|
||
# 进入 Halo 项目根目录后,使用 cd 命令进入配置文件目录
|
||
cd application/src/main/resources
|
||
|
||
# 创建 application-local.yaml 文件
|
||
touch application-local.yaml
|
||
```
|
||
|
||
根据你的操作系统,将以下内容添加到 `application-local.yaml` 文件中。
|
||
|
||
```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
|
||
|
||
```shell
|
||
# 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`
|
||
|
||
在插件列表将能看到插件已经被正确启动,并且在左侧菜单添加了一个 `示例分组`,其下有一个名 `示例页面` 的菜单。
|
||
|
||

|