webman-tech / swagger
Webman plugin webman-tech/swagger
Requires
- php: ^8.2
- webman-tech/common-utils: ^5.0 || dev-main
- webman-tech/dto: ^5.0 || dev-main
- zircote/swagger-php: >=5.2 <5.5
- dev-main
- v5.0.20
- v5.0.19
- v5.0.18
- v5.0.17
- v5.0.16
- v5.0.15
- v5.0.14
- v5.0.13
- v5.0.12
- v5.0.11
- v5.0.10
- v5.0.9
- v5.0.8
- v5.0.7
- v5.0.6
- v5.0.5
- v5.0.4
- v5.0.3
- v5.0.2
- v5.0.1
- v5.0.0
- v2.1.4
- v2.1.3
- v2.1.2
- v2.1.1
- v2.1.0
- v2.0.0
- v1.5.1
- v1.5.0
- v1.4.1
- v1.4.0
- v1.3.1
- v1.3.0
- v1.2.1
- v1.2.0
- v1.1.0
- v1.0.28
- v1.0.27
- v1.0.26
- v1.0.25
- v1.0.24
- v1.0.23
- v1.0.22
- v1.0.21
- v1.0.20
- v1.0.19
- v1.0.18
- v1.0.17
- v1.0.16
- v1.0.15
- v1.0.14
- v1.0.13
- v1.0.12
- v1.0.11
- v1.0.10
- v1.0.9
- v1.0.8
- v1.0.7
- v1.0.6
- v1.0.5
- v1.0.4
- v1.0.3
- v1.0.2
- v1.0.1
- v1.0.0
- dev-1.5.1-bk
- dev-dev-validate
- dev-通过注解做验证器
This package is auto-updated.
Last update: 2026-04-23 08:00:49 UTC
README
本项目是从 webman-tech/components-monorepo 自动 split 出来的,请勿直接修改
简介
Swagger OpenAPI 在 webman 中的一键配置启用方案,基于 zircote/swagger-php 实现。
该组件提供了一种简便的方式来为 webman 应用生成和展示 API 文档,支持通过注解或属性(Attribute)方式定义 API 接口,并自动生成对应的 OpenAPI 文档和 Swagger UI 界面。
功能特性
- 零配置启动:安装后直接访问
/openapi即可看到 Swagger UI 界面 - 多文档支持:支持单应用下多个 Swagger 文档(多路由,不同 API 文档)
- 动态配置:支持动态修改注解下的 Swagger 文档,解决注解下无法写动态配置的问题
- 丰富配置:支持 host 访问限制、Swagger UI 配置、OpenAPI 配置等
- 性能优化:服务启动后缓存文档内容,开发环境支持自动更新
- 路由自动注册:支持自动注册 webman 路由
- 跨框架兼容:不仅支持 webman 环境,也可在其他环境中使用
安装
composer require webman-tech/swagger
核心组件
Swagger 主类
Swagger 是主要入口,提供 registerGlobalRoute() 注册全局路由和 registerRoute() 注册自定义路由两个方法。
配置 DTO
ConfigRegisterRouteDTO
路由注册配置,控制路由注册行为,包含启用开关(enable)、路由前缀(route_prefix)、访问权限控制(host_forbidden)、Basic 认证(basic_auth)、Swagger UI 配置(swagger_ui)、OpenAPI 文档配置(openapi_doc)、是否注册 webman 路由(register_route)及额外中间件(middlewares)。
ConfigBasicAuthDTO
Basic 认证配置,默认关闭。启用后访问 Swagger UI 和 OpenAPI 文档时需要提供用户名和密码。支持配置用户名(username)、密码(password)和认证提示域(realm)。
ConfigOpenapiDocDTO
OpenAPI 文档配置,默认输出版本为 OpenAPI 3.1.0,支持扫描目录(scan_path)、排除目录(scan_exclude)、文档格式(format,yaml/json)、运行时动态修改回调(modify)、缓存键(cache_key)及 Schema 相关配置。
ConfigSwaggerUiDTO
Swagger UI 配置,支持自定义视图(view)、视图路径(view_path)、静态资源基础 URL(assets_base_url)及视图数据(data)。
ConfigHostForbiddenDTO
主机访问限制配置,支持启用开关(enable)、允许内网访问(ip_white_list_intranet)、IP 白名单(ip_white_list)及主机白名单(host_white_list)。默认仅允许内网环境访问。
OpenapiController
OpenapiController 负责处理文档展示,提供 swaggerUI() 展示 Swagger UI 界面和 openapiDoc() 返回 OpenAPI 文档内容两个动作。
Reader 路由注解解析
Reader 用于解析 OpenAPI 注解并生成路由配置。
SchemaConstants 常量定义
SchemaConstants 定义了用于 Schema 的扩展常量,包括 X_NAME(命名路由)、X_PATH(路由路径)、X_MIDDLEWARE(路由中间件)、X_SCHEMA_REQUEST(请求 Schema)、X_SCHEMA_RESPONSE(响应 Schema)。
参考示例
AI 辅助
- 开发维护:AGENTS.md — 面向 AI 的代码结构和开发规范说明
- 使用指南:skills/webman-tech-swagger-best-practices/SKILL.md — 面向 AI 的最佳实践,可安装到 Claude Code 的 skills 目录使用