Laravel如何为API生成Swagger或OpenAPI文档

发布时间 - 2025-12-12 00:00:00    点击率:
使用DarkaOnLine/L5-Swagger包通过注解自动生成OpenAPI文档,1. 安装并发布配置文件;2. 配置扫描路径与路由;3. 在控制器中添加@OA注解描述接口;4. 生成文档并访问/api/documentation查看交互式页面;5. 可选自动更新机制保持文档同步。

在Laravel项目中为API生成Swagger(OpenAPI)文档,最常用且高效的方式是使用DarkaOnLine/L5-Swagger包。它基于Swagger PHP注解,能自动生成符合OpenAPI规范的交互式API文档。

1. 安装 L5-Swagger 包

在Laravel项目根目录下运行以下命令安装:

composer require "darkaonline/l5-swagger"

安装完成后,发布配置文件:

php artisan vendor:publish --provider "L5Swagger\L5SwaggerServiceProvider"

这会生成 config/l5-swagger.php 和视图资源文件。

2. 配置 Swagger 文档路径与扫描

打开 config/l5-swagger.php,确认以下关键配置项:

  • routes.api:访问文档的路由,如 /api/documentation
  • paths.docs:文档存储路径,默认为 storage/api-docs/
  • paths.annotations:注解扫描路径,通常设为 ./app/Http/Controllers

确保扫描路径包含你写注解的控制器或API类。

3. 在控制器中编写 OpenAPI 注解

使用PHP注解为API接口添加描述。例如:

/** * @OA\Get( * path="/api/users", * tags={"Users"}, * summary="获取用户列表", * @OA\Response( * response=200, * description="成功返回用户列表", * @OA\JsonContent(type="array", @OA\Items(ref="#/components/schemas/User")) * ) * ) */ public function index() { return User::all(); }

支持的注解包括:@OA\Info@OA\PathItem@OA\Schema 等,完整语法参考 Swagger-PHP 官方文档。

4. 生成和查看文档

运行以下命令生成JSON格式的OpenAPI文档:

php artisan l5-swagger:generate

启动Laravel服务后,访问:

http://your-app.test/api/documentation

即可查看由Swagger UI渲染的交互式API文档页面。

5. (可选)自动更新文档

开发阶段可在 AppServiceProvider 或使用监听器,在代码变更时自动重新生成文档,或在CI流程中加入生成命令。

基本上就这些。只要写好注解并正确配置,L5-Swagger就能帮你维护一份实时、可视化的API文档。


# php  # laravel  # js  # json  # composer  # app  # 路由  # 配置文件  # Array  # require  # 接口  # public  # 并发  # function  # http  # ui  # 文档  # 可选  # 自动生成  # 用户列表  # 自动更新  # 器中  # 就能  # 设为  # 帮你 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel表单请求验证类怎么用_Laravel Form Request分离验证逻辑教程  Laravel如何使用模型观察者?(Observer代码示例)  如何在企业微信快速生成手机电脑官网?  如何在万网ECS上快速搭建专属网站?  在centOS 7安装mysql 5.7的详细教程  html如何与html链接_实现多个HTML页面互相链接【互相】  Windows驱动无法加载错误解决方法_驱动签名验证失败处理步骤  高端云建站费用究竟需要多少预算?  java ZXing生成二维码及条码实例分享  Android okhttputils现在进度显示实例代码  Python正则表达式进阶教程_复杂匹配与分组替换解析  Laravel API资源(Resource)怎么用_格式化Laravel API响应的最佳实践  今日头条微视频如何找选题 今日头条微视频找选题技巧【指南】  Laravel怎么返回JSON格式数据_Laravel API资源Response响应格式化【技巧】  Javascript中的事件循环是如何工作的_如何利用Javascript事件循环优化异步代码?  ai格式如何转html_将AI设计稿转换为HTML页面流程【页面】  香港服务器网站生成指南:免费资源整合与高速稳定配置方案  *服务器网站为何频现安全漏洞?  Mybatis 中的insertOrUpdate操作  ,怎么在广州志愿者网站注册?  网站建设整体流程解析,建站其实很容易!  Laravel定时任务怎么设置_Laravel Crontab调度器配置  google浏览器怎么清理缓存_谷歌浏览器清除缓存加速详细步骤  如何在服务器上三步完成建站并提升流量?  EditPlus中的正则表达式实战(6)  Laravel请求验证怎么写_Laravel Validator自定义表单验证规则教程  利用python获取某年中每个月的第一天和最后一天  使用Dockerfile构建java web环境  如何在宝塔面板中修改默认建站目录?  Android自定义控件实现温度旋转按钮效果  Win11搜索不到蓝牙耳机怎么办 Win11蓝牙驱动更新修复【详解】  如何在浏览器中启用Flash_2025年继续使用Flash Player的方法【过时】  标题:Vue + Vuex + JWT 身份认证的正确实践与常见误区解析  如何在云主机上快速搭建多站点网站?  🚀拖拽式CMS建站能否实现高效与个性化并存?  WordPress 子目录安装中正确处理脚本路径的完整指南  进行网站优化必须要坚持的四大原则  Laravel Artisan命令怎么自定义_创建自己的Laravel命令行工具完全指南  海南网站制作公司有哪些,海口网是哪家的?  详解jQuery中基本的动画方法  实例解析angularjs的filter过滤器  中山网站制作网页,中山新生登记系统登记流程?  Windows10电脑怎么设置虚拟光驱_Win10右键装载ISO镜像文件  如何快速配置高效服务器建站软件?  深入理解Android中的xmlns:tools属性  Win11怎么修改DNS服务器 Win11设置DNS加速网络【指南】  Laravel用户认证怎么做_Laravel Breeze脚手架快速实现登录注册功能  深圳网站制作平台,深圳市做网站好的公司有哪些?  微信小程序 HTTPS报错整理常见问题及解决方案  ,网页ppt怎么弄成自己的ppt?