- Created by 郭强, last modified by 张金富 on May 29, 2023
基本介绍
GoFrame
的Server
默认自带的OpenAPI
接口文档UI是redoc
开源组件,该组件不支持页面Try It Out
功能的。很多同学都在问,能否使用SwaggerUI
页面来展示OpenAPI
接口文档?有的企业内部并不支持连接外网的部分资源,那么能否将内部的接口文档UI替换为内部可访问的资源呢?
了解OpenAPI
这个东东的小伙伴应该都知道,OpenAPI
只是通用的接口定义规范,而展示的接口文档UI是可以随便替换的,并且这种UI界面以及平台还特别多!使用GoFrame Server
来切换接口文档UI页面,或者将接口文档对接到第三方接口文档平台 - 非常简单!
使用示例
咱们通过代码来展示一下,如果快速地将接口文档UI切换为SwaggerUI
。SwaggerUI
的相关链接:
- https://github.com/swagger-api/swagger-ui
- https://github.com/swagger-api/swagger-ui/blob/master/docs/usage/installation.md
为了演示简便,这里将所有的代码都写到一个代码文件中,没有使用配置或页面文件。代码如下:
package main import ( "context" "fmt" "github.com/gogf/gf/v2/frame/g" "github.com/gogf/gf/v2/net/ghttp" ) const ( swaggerUIPageContent = ` <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1" /> <meta name="description" content="SwaggerUI"/> <title>SwaggerUI</title> <link rel="stylesheet" href="https://unpkg.com/swagger-ui-dist@latest/swagger-ui.css" /> </head> <body> <div id="swagger-ui"></div> <script src="https://unpkg.com/swagger-ui-dist@latest/swagger-ui-bundle.js" crossorigin></script> <script> window.onload = () => { window.ui = SwaggerUIBundle({ url: '/api.json', dom_id: '#swagger-ui', }); }; </script> </body> </html> ` ) type HelloReq struct { g.Meta `path:"/hello" method:"get"` Name string `v:"required" dc:"Your name"` } type HelloRes struct { Reply string `dc:"Reply content"` } type Hello struct{} func (Hello) Say(ctx context.Context, req *HelloReq) (res *HelloRes, err error) { g.Log().Debugf(ctx, `receive say: %+v`, req) res = &HelloRes{ Reply: fmt.Sprintf(`Hi %s`, req.Name), } return } func main() { s := g.Server() s.Use(ghttp.MiddlewareHandlerResponse) s.Group("/", func(group *ghttp.RouterGroup) { group.GET("/swagger", func(r *ghttp.Request) { r.Response.Write(swaggerUIPageContent) }) group.Bind( new(Hello), ) }) s.SetOpenApiPath("/api.json") s.SetPort(8199) s.Run() }
我们这里只定义了一个Hello
的接口。可以看到,我们通过一个接口来展示SwaggerUI
的HTML
页面,并且将OpenAPI
的接口文件路径定义为/api.json
,没有启用Server
自带的UI页面。执行后,终端输出:
2022-05-18 20:41:09.160 [INFO] openapi specification is serving at address: http://127.0.0.1:8199/api.json 2022-05-18 20:41:09.161 [INFO] pid[57888]: http server started listening on [:8199] ADDRESS | METHOD | ROUTE | HANDLER | MIDDLEWARE ----------|--------|-----------|-----------------------------------------------------------------|-------------------- :8199 | ALL | /* | github.com/gogf/gf/v2/net/ghttp.internalMiddlewareServerTracing | GLOBAL MIDDLEWARE ----------|--------|-----------|-----------------------------------------------------------------|-------------------- :8199 | ALL | /api.json | github.com/gogf/gf/v2/net/ghttp.(*Server).openapiSpec | ----------|--------|-----------|-----------------------------------------------------------------|-------------------- :8199 | GET | /hello | main.(*Hello).Say | ----------|--------|-----------|-----------------------------------------------------------------|-------------------- :8199 | GET | /swagger | main.main.func1.1 | ----------|--------|-----------|-----------------------------------------------------------------|--------------------
戳此链接访问:http://127.0.0.1:8199/swagger/
页面展示如下:
开发者自定义其他的接口文档UI类似如此。
提示
需要注释掉config.yaml文件中的 swaggerPath: "/swagger" 这一行,否则界面不会改变
Content Menu
- No labels
10 Comments
Henry Hall
上面的示例使用的是swaggerui的js文件,但是在Goframe源码中,引用了一个redoc.standalone.js文件,一直超时。
我下载了最新版的goframe(2.1.0-rc3),初始化工程,什么都不改动,启动后,直接访问http://localhost:8199/swagger,一直在加载中。
建议把源码中那段ui的html改成示例中的。
郭强
新版本已修改。
guosong
gf版本2.1.4用nginx反向代理时候swagger报错,不能自动调用二级目录,默认调用的/api.js到根域名下了。
我的config.yaml配置如下:
server:
address: "0.0.0.0:8199"
openapiPath: "/api.json"
swaggerPath: "/swagger"
请求swagger域名如下:https://www.banbantest.com/mytest/swagger
正确的api.js应该是:https://www.banbantest.com/mytest/api.js,而我又找不到修改这个路径的地方
报错如下:
Something went wrong...
Failed to load https://www.banbantest.com/api.json: 404 Not Found
Stack trace
ReDoc Version: 2.0.0-rc.70
Commit: 036f97d
海亮
反向代理自行修改相应的代理配置
angelandy
我发现 api.json 会把所有 请求地址和 数据schemas 都在一个接口返回
我不清楚这个是不是 openapi 的标准
但会导致以下问题
1、理论上 当项目越来越大,这个json 会很大,解析会比较难。
改进建议,把schemas 不再同一个页面展示,而是通过ajax 按需加载
2、tags 是放在path 下面的,不方便渲染页面 理论上应该 tag 下面同tag 的path
海亮
如果你看看如何改进就更好了,毕竟作者精力有限
郭强
openapi
就是这样的。fangyu
method怎么支持多个方式啊,比如可以让get和options一起
糖水不加糖
用原始方式注册路由
阿星
有没有更友好的方式使用swaggerui呢,目前生成的项目模板,配置了这个并没有用,要把manifest/config/config.yaml文件中默认生成的swaggerPath删掉,然后在internal/cmd/cmd.go中加上上面那些代码才可以生效。刚接触这个框架,差点劝退了