Laravel 11 中的 API 版本控制

发布于 作者

API Versioning in Laravel 11 image

随着 Laravel 11 的发布,应用程序骨架被精简,去除了每个项目都不需要的额外文件。该更改的一部分是将除了 AppServiceProvider 之外的所有服务提供者从应用程序源代码中删除。

更新后的应用程序骨架的另一个部分是删除默认安装中的 API 路由。假设您计划将 API 添加到您的应用程序或使用 Laravel 专门编写 API,在这种情况下,您可以使用 Artisan 命令设置 api 中间件组和路由

php artisan install:api

install:api 会设置 api.php 路由文件(并配置它)、个人访问令牌的数据库迁移以及 Sanctum 配置文件。如果您不需要对 API 进行版本控制,则只需执行此操作即可。

在单独的文件中对 API 进行版本控制

在 Laravel 中编写版本化 API 的一种常见方法是将路由分离到不同的文件中。这样做可以简化推理特定 API 版本的开销,并保持整洁。在 Laravel 10 或更早版本中,一种常见的方法是为 RouteServiceProvider 中的每个 API 版本添加额外的路由文件

$this->routes(function () {
Route::middleware('api')
->prefix('api')
->group(base_path('routes/api.php'));
 
Route::middleware('api')
->prefix('api/v1')
->group(base_path('routes/api_v1.php'));
 
Route::middleware('api')
->prefix('api/v2')
->group(base_path('routes/api_v2.php'));
 
Route::middleware('web')
->group(base_path('routes/web.php'));
});

在上面的示例中,routes/api.php 通常为 Laravel Sanctum 提供 /user 端点,其余的 API 路由则放置在相应的版本中。

在 Laravel 11 中对 API 进行版本控制

随着路由引导从 RouteServiceProvider 转移到 bootstrap/app.php,您可以使用以下几种方法对 API 进行版本控制。

首先,让我们生成一些文件来演示路由设置

touch routes/api_v1.php
touch routes/api_v2.php
 
php artisan make:controller --api Api/V1/PostsController
php artisan make:controller --api Api/V2/PostsController

使用任何适合您的文件名约定和位置。

接下来,打开 routes/api.php 文件,并将以下行添加到文件末尾

Route::prefix('v1')->group(base_path('routes/api_v1.php'));
Route::prefix('v2')->group(base_path('routes/api_v2.php'));

上面的代码位于 api.php 中,这意味着我们已经在 api 路由前缀内工作,并使用 api 中间件组。

接下来,让我们添加每个 API 版本的示例路由,以便我们可以可视化每个版本的路由列表。

这是 api_v1.php 文件

<?php
 
use App\Http\Controllers\Api\V1\PostsController;
 
Route::apiResource('posts', PostsController::class);

以及 api_v2.php 文件

<?php
 
use App\Http\Controllers\Api\V2\PostsController;
 
Route::apiResource('posts', PostsController::class);

定义完路由文件后,运行 route:list,我们可以看到版本化路由!

专业提示: 您可以使用 --path 标志隔离版本化路由,从而可以轻松地专注于特定 API 版本

php artisan route:list --path=api/v1
php artisan route:list --path=api/v2

看看如果您只输出 api/v2 的路由,它看起来多么整洁

在 App 引导文件中定义版本化路由

我见过的另一种方法是在 bootstrap/app.php 文件中使用 then: 参数(接受 Closure)定义额外的 API 路由

return Application::configure(basePath: dirname(__DIR__))
->withRouting(
web: __DIR__.'/../routes/web.php',
api: __DIR__.'/../routes/api.php',
commands: __DIR__.'/../routes/console.php',
health: '/up',
then: function () {
Route::middleware('api')
->prefix('api/v1')
->group(base_path('routes/api/api_v1.php'));
 
Route::middleware('api')
->prefix('api/v2')
->group(base_path('routes/api/api_v2.php'));
}
)
// ...
;

我更喜欢将额外的路由文件直接添加到 routes/api.php 中,但这是一种可行的替代方法。在引导文件中定义路由时,这些组未配置为使用 api 中间件组。请确保在这些路由中包含 api 中间件组!

Paul Redmond photo

Laravel 新闻的撰稿人。全栈 Web 开发人员和作者。

Cube

Laravel 新闻稿

加入 40,000 多位其他开发人员,绝不错过新的提示、教程等。

Laravel Forge logo

Laravel Forge

轻松创建和管理您的服务器,并在几秒钟内部署您的 Laravel 应用程序。

Laravel Forge
Tinkerwell logo

Tinkerwell

Laravel 开发人员必备的代码运行器。使用 AI、自动完成和对本地和生产环境的即时反馈进行调试。

Tinkerwell
No Compromises logo

No Compromises

来自 No Compromises 播客的两位经验丰富的开发人员 Joel 和 Aaron 现在可供您为您的 Laravel 项目聘用。 ⬧ 固定费率 7500 美元/月。 ⬧ 无需冗长的销售流程。 ⬧ 无需签订合同。 ⬧ 100% 退款保证。

No Compromises
Kirschbaum logo

Kirschbaum

提供创新和稳定性,确保您的 Web 应用程序取得成功。

Kirschbaum
Shift logo

Shift

正在运行旧版本的 Laravel?即时、自动化的 Laravel 升级和代码现代化,使您的应用程序保持新鲜。

Shift
Bacancy logo

Bacancy

仅需每月 2500 美元,即可用经验丰富的 Laravel 开发人员(拥有 4-6 年经验)为您的项目提供动力。获得 160 小时的专职专业知识和 15 天无风险试用期。立即安排电话咨询!

Bacancy
Lucky Media logo

Lucky Media

立即获得 Lucky - Laravel 开发的理想选择,拥有超过十年的经验!

Lucky Media
Lunar: Laravel E-Commerce logo

Lunar: Laravel 电子商务

Laravel 电子商务。一个开源包,将现代无头电子商务功能的强大功能带到 Laravel。

Lunar: Laravel 电子商务
LaraJobs logo

LaraJobs

官方 Laravel 职位招聘网站

LaraJobs
SaaSykit: Laravel SaaS Starter Kit logo

SaaSykit: Laravel SaaS 启动工具包

SaaSykit 是一款 Laravel SaaS 启动工具包,包含运行现代 SaaS 所需的所有功能。支付、漂亮的结账页面、管理面板、用户仪表板、身份验证、现成的组件、统计数据、博客、文档等等。

SaaSykit: Laravel SaaS 启动工具包
Rector logo

Rector

您实现 Laravel 无缝升级、降低成本和加速创新以助力公司成功的合作伙伴

Rector
MongoDB logo

MongoDB

通过将 MongoDB 和 Laravel 强力集成,增强您的 PHP 应用程序,使开发人员能够轻松高效地构建应用程序。支持事务性、搜索、分析和移动用例,同时使用熟悉的 Eloquent API。了解灵活、现代的 MongoDB 数据库如何改变您的 Laravel 应用程序。

MongoDB
Maska is a Simple Zero-dependency Input Mask Library image

Maska 是一个简单的零依赖输入掩码库

阅读文章
Add Swagger UI to Your Laravel Application image

在您的 Laravel 应用程序中添加 Swagger UI

阅读文章
Assert the Exact JSON Structure of a Response in Laravel 11.19 image

在 Laravel 11.19 中断言响应的精确 JSON 结构

阅读文章
Build SSH Apps with PHP and Laravel Prompts image

使用 PHP 和 Laravel 提示构建 SSH 应用程序

阅读文章
Building fast, fuzzy site search with Laravel and Typesense image

使用 Laravel 和 Typesense 构建快速、模糊的网站搜索

阅读文章
Add Comments to your Laravel Application with the Commenter Package image

使用 Commenter 包在您的 Laravel 应用程序中添加评论

阅读文章