主题
Laravel Boost
简介
Laravel Boost 通过提供必要的指导原则和代理技能来加速 AI 辅助开发,帮助 AI 代理编写遵循 Laravel 最佳实践的高质量 Laravel 应用程序。
Boost 还提供了强大的 Laravel 生态系统文档 API,它结合了内置的 MCP 工具和包含超过 17,000 条 Laravel 特定信息的广泛知识库,所有这些都通过使用嵌入的语义搜索功能增强,以实现精确的、上下文感知的结果。Boost 指导 Claude Code 和 Cursor 等 AI 代理使用此 API 来了解最新的 Laravel 功能和最佳实践。
安装
Laravel Boost 可以通过 Composer 安装:
shell
composer require laravel/boost --dev接下来,安装 MCP 服务器和编码指导原则:
shell
php artisan boost:installboost:install 命令将为您在安装过程中选择的编码代理生成相关的代理指导原则和技能文件。
安装 Laravel Boost 后,您就可以开始使用 Cursor、Claude Code 或您选择的 AI 代理进行编码了。
NOTE
您可以将生成的 MCP 配置文件(.mcp.json)、指导原则文件(CLAUDE.md、AGENTS.md、junie/ 等)和 boost.json 配置文件添加到应用程序的 .gitignore 中,因为这些文件在运行 boost:install 和 boost:update 时会自动重新生成。
设置您的代理
text
1. 打开命令面板(`Cmd+Shift+P` 或 `Ctrl+Shift+P`)
2. 在 "/open MCP Settings" 上按 `enter`
3. 打开 `laravel-boost` 的开关text
Claude Code 支持通常会自动启用。如果您发现没有启用,请在项目目录中打开 shell 并运行以下命令:
claude mcp add -s local -t stdio laravel-boost php artisan boost:mcptext
Codex 支持通常会自动启用。如果您发现没有启用,请在项目目录中打开 shell 并运行以下命令:
codex mcp add laravel-boost -- php "artisan" "boost:mcp"text
Gemini CLI 支持通常会自动启用。如果您发现没有启用,请在项目目录中打开 shell 并运行以下命令:
gemini mcp add -s project -t stdio laravel-boost php artisan boost:mcptext
1. 打开命令面板(`Cmd+Shift+P` 或 `Ctrl+Shift+P`)
2. 在 "MCP: List Servers" 上按 `enter`
3. 用箭头键选择 `laravel-boost` 并按 `enter`
4. 选择 "Start server"text
1. 按两次 `shift` 打开命令面板
2. 搜索 "MCP Settings" 并按 `enter`
3. 勾选 `laravel-boost` 旁边的复选框
4. 点击右下角的 "Apply"保持 Boost 资源更新
您可能需要定期更新本地 Boost 资源(AI 指导原则和技能),以确保它们反映您已安装的 Laravel 生态系统包的最新版本。为此,您可以使用 boost:update Artisan 命令。
shell
php artisan boost:update您还可以通过将其添加到 Composer 的 "post-update-cmd" 脚本来自动化此过程:
json
{
"scripts": {
"post-update-cmd": [
"@php artisan boost:update --ansi"
]
}
}MCP 服务器
Laravel Boost 提供了一个 MCP(模型上下文协议)服务器,该服务器公开工具供 AI 代理与您的 Laravel 应用程序交互。这些工具使代理能够检查应用程序的结构、查询数据库、执行代码等。
可用的 MCP 工具
| 名称 | 说明 |
|---|---|
| Application Info | 读取 PHP 和 Laravel 版本、数据库引擎、生态系统包列表及其版本,以及 Eloquent 模型 |
| Browser Logs | 读取浏览器中的日志和错误 |
| Database Connections | 检查可用的数据库连接,包括默认连接 |
| Database Query | 对数据库执行查询 |
| Database Schema | 读取数据库架构 |
| Get Absolute URL | 将相对路径 URI 转换为绝对路径,以便代理生成有效的 URL |
| Get Config | 使用"点"表示法从配置文件中获取值 |
| Last Error | 从应用程序的日志文件中读取最后一个错误 |
| List Artisan Commands | 检查可用的 Artisan 命令 |
| List Available Config Keys | 检查可用的配置键 |
| List Available Env Vars | 检查可用的环境变量键 |
| List Routes | 检查应用程序的路由 |
| Read Log Entries | 读取最后 N 条日志条目 |
| Search Docs | 查询 Laravel 托管的文档 API 服务,根据已安装的包检索文档 |
| Tinker | 在应用程序上下文中执行任意代码 |
手动注册 MCP 服务器
有时您可能需要手动将 Laravel Boost MCP 服务器注册到您选择的编辑器中。您应该使用以下详细信息注册 MCP 服务器:
| 命令 | php |
| 参数 | artisan boost:mcp |
JSON 示例:
json
{
"mcpServers": {
"laravel-boost": {
"command": "php",
"args": ["artisan", "boost:mcp"]
}
}
}AI 指导原则
AI 指导原则是可组合的指令文件,在启动时加载,为 AI 代理提供关于 Laravel 生态系统包的基本上下文。这些指导原则包含核心约定、最佳实践和框架特定模式,帮助代理生成一致的、高质量的代码。
可用的 AI 指导原则
Laravel Boost 包含以下包和框架的 AI 指导原则。core 指导原则为给定包提供通用的、适用于所有版本的建议。
| 包 | 支持的版本 |
|---|---|
| Core & Boost | core |
| Laravel Framework | core, 10.x, 11.x, 12.x |
| Livewire | core, 2.x, 3.x, 4.x |
| Flux UI | core, free, pro |
| Folio | core |
| Herd | core |
| Inertia Laravel | core, 1.x, 2.x |
| Inertia React | core, 1.x, 2.x |
| Inertia Vue | core, 1.x, 2.x |
| Inertia Svelte | core, 1.x, 2.x |
| MCP | core |
| Pennant | core |
| Pest | core, 3.x, 4.x |
| PHPUnit | core |
| Pint | core |
| Sail | core |
| Tailwind CSS | core, 3.x, 4.x |
| Livewire Volt | core |
| Wayfinder | core |
| Enforce Tests | conditional |
注意: 要保持 AI 指导原则为最新状态,请参阅保持 Boost 资源更新部分。
添加自定义 AI 指导原则
要使用您自己的自定义 AI 指导原则来增强 Laravel Boost,请将 .blade.php 或 .md 文件添加到应用程序的 .ai/guidelines/* 目录中。当您运行 boost:install 时,这些文件将自动包含在 Laravel Boost 的指导原则中。
覆盖 Boost AI 指导原则
您可以通过创建具有匹配文件路径的自定义指导原则来覆盖 Boost 的内置 AI 指导原则。当您创建的自定义指导原则与现有 Boost 指导原则路径匹配时,Boost 将使用您的自定义版本而不是内置版本。
例如,要覆盖 Boost 的 "Inertia React v2 Form Guidance" 指导原则,请在 .ai/guidelines/inertia-react/2/forms.blade.php 创建一个文件。当您运行 boost:install 时,Boost 将包含您的自定义指导原则而不是默认的。
第三方包 AI 指导原则
如果您维护一个第三方包并希望 Boost 包含其 AI 指导原则,您可以在包中添加一个 resources/boost/guidelines/core.blade.php 文件。当您的包的用户运行 php artisan boost:install 时,Boost 将自动加载您的指导原则。
AI 指导原则应提供包功能的简短概述,概述任何必需的文件结构或约定,并解释如何创建或使用其主要功能(附带示例命令或代码片段)。保持简洁、可操作,并专注于最佳实践,以便 AI 能为您的用户生成正确的代码。以下是一个示例:
php
## Package Name
This package provides [brief description of functionality].
### Features
- Feature 1: [clear & short description].
- Feature 2: [clear & short description]. Example usage:
@verbatim
<code-snippet name="How to use Feature 2" lang="php">
$result = PackageName::featureTwo($param1, $param2);
</code-snippet>
@endverbatim代理技能
代理技能是轻量级的、有针对性的知识模块,代理可以在处理特定领域时按需激活。与预先加载的指导原则不同,技能允许仅在相关时加载详细的模式和最佳实践,减少上下文膨胀并提高 AI 生成代码的相关性。
当您运行 boost:install 并选择技能作为功能时,技能会根据 composer.json 中检测到的包自动安装。例如,如果您的项目包含 livewire/livewire,livewire-development 技能将自动安装。
可用技能
| 技能 | 包 |
|---|---|
| fluxui-development | Flux UI |
| folio-routing | Folio |
| inertia-react-development | Inertia React |
| inertia-svelte-development | Inertia Svelte |
| inertia-vue-development | Inertia Vue |
| livewire-development | Livewire |
| mcp-development | MCP |
| pennant-development | Pennant |
| pest-testing | Pest |
| tailwindcss-development | Tailwind CSS |
| volt-development | Volt |
| wayfinder-development | Wayfinder |
注意: 要保持技能为最新状态,请参阅保持 Boost 资源更新部分。
自定义技能
要创建您自己的自定义技能,请在应用程序的 .ai/skills/{skill-name}/ 目录中添加一个 SKILL.md 文件。当您运行 boost:update 时,您的自定义技能将与 Boost 的内置技能一起安装。
例如,要为应用程序的领域逻辑创建自定义技能:
.ai/skills/creating-invoices/SKILL.md覆盖技能
您可以通过创建具有匹配名称的自定义技能来覆盖 Boost 的内置技能。当您创建的自定义技能与现有 Boost 技能名称匹配时,Boost 将使用您的自定义版本而不是内置版本。
例如,要覆盖 Boost 的 livewire-development 技能,请在 .ai/skills/livewire-development/SKILL.md 创建一个文件。当您运行 boost:update 时,Boost 将包含您的自定义技能而不是默认的。
第三方包技能
如果您维护一个第三方包并希望 Boost 包含其技能,您可以在包中添加一个 resources/boost/skills/{skill-name}/SKILL.md 文件。当您的包的用户运行 php artisan boost:install 时,Boost 将根据用户偏好自动安装您的技能。
Boost 技能支持代理技能格式,应该构建为包含带有 YAML frontmatter 和 Markdown 指令的 SKILL.md 文件的文件夹。SKILL.md 文件必须包含必需的 frontmatter(name 和 description),并且可以选择性地包含脚本、模板和参考材料。
技能应概述任何必需的文件结构或约定,并解释如何创建或使用其主要功能(附带示例命令或代码片段)。保持简洁、可操作,并专注于最佳实践,以便 AI 能为您的用户生成正确的代码:
markdown
---
name: package-name-development
description: Build and work with PackageName features, including components and workflows.
---
# Package Name Development
## When to use this skill
Use this skill when working with PackageName features...
## Features
- Feature 1: [clear & short description].
- Feature 2: [clear & short description]. Example usage:
$result = PackageName::featureTwo($param1, $param2);指导原则 vs. 技能
Laravel Boost 提供了两种不同的方式来为 AI 代理提供关于应用程序的上下文:指导原则和技能。
指导原则在 AI 代理启动时预先加载,提供关于 Laravel 约定和最佳实践的基本上下文,这些上下文广泛适用于整个代码库。
技能在处理特定任务时按需激活,包含特定领域的详细模式(如 Livewire 组件或 Pest 测试)。仅在相关时加载技能可以减少上下文膨胀并提高代码质量。
| 方面 | 指导原则 | 技能 |
|---|---|---|
| 加载方式 | 预先加载,始终存在 | 按需加载,在相关时 |
| 范围 | 广泛的、基础性的 | 聚焦的、任务特定的 |
| 目的 | 核心约定和最佳实践 | 详细的实现模式 |
文档 API
Laravel Boost 包含一个文档 API,为 AI 代理提供访问包含超过 17,000 条 Laravel 特定信息的广泛知识库。该 API 使用带有嵌入的语义搜索来提供精确的、上下文感知的结果。
Search Docs MCP 工具允许代理查询 Laravel 托管的文档 API 服务,根据已安装的包检索文档。Boost 的 AI 指导原则和技能将自动指导您的编码代理使用此 API。
| 包 | 支持的版本 |
|---|---|
| Laravel Framework | 10.x, 11.x, 12.x |
| Filament | 2.x, 3.x, 4.x, 5.x |
| Flux UI | 2.x Free, 2.x Pro |
| Inertia | 1.x, 2.x |
| Livewire | 1.x, 2.x, 3.x, 4.x |
| Nova | 4.x, 5.x |
| Pest | 3.x, 4.x |
| Tailwind CSS | 3.x, 4.x |
扩展 Boost
Boost 开箱即用地支持许多流行的 IDE 和 AI 代理。如果您的编码工具尚未被支持,您可以创建自己的代理并将其与 Boost 集成。
添加对其他 IDE / AI 代理的支持
要添加对新 IDE 或 AI 代理的支持,请创建一个扩展 Laravel\Boost\Install\Agents\Agent 的类,并根据需要实现以下一个或多个契约:
Laravel\Boost\Contracts\SupportsGuidelines- 添加对 AI 指导原则的支持。Laravel\Boost\Contracts\SupportsMcp- 添加对 MCP 的支持。Laravel\Boost\Contracts\SupportsSkills- 添加对代理技能的支持。
编写代理
php
<?php
declare(strict_types=1);
namespace App;
use Laravel\Boost\Contracts\SupportsGuidelines;
use Laravel\Boost\Contracts\SupportsMcp;
use Laravel\Boost\Contracts\SupportsSkills;
use Laravel\Boost\Install\Agents\Agent;
class CustomAgent extends Agent implements SupportsGuidelines, SupportsMcp, SupportsSkills
{
// 您的实现...
}有关示例实现,请参阅 ClaudeCode.php。
注册代理
在应用程序的 App\Providers\AppServiceProvider 的 boot 方法中注册您的自定义代理:
php
use Laravel\Boost\Boost;
public function boot(): void
{
Boost::registerAgent('customagent', CustomAgent::class);
}注册后,您的代理将在运行 php artisan boost:install 时可供选择。
