Gin之使用swagger生成接口文档

Gin之使用swagger生成接口文档

1.下载安装依赖

go get -u github.com/swaggo/swag/cmd/swag  (swag cli) 
go get github.com/swaggo/gin-swagger  (gin-swagger)
go get github.com/swaggo/gin-swagger/swaggerFiles  (swagger内置文件)
注:生成的依赖都在pkg目录下

image-20220207121500643

2.swagger介绍

image-20220207121715298

3.使用步骤

image-20220207121747353

4.写注释

package main

import (
	"github.com/gin-gonic/gin"
	"net/http"
)



// @title Swagger Example API
// @version 1.0
// @description This is a sample server celler server.
// @termsOfService https://razeen.me

// @contact.name Razeen
// @contact.url https://razeen.me
// @contact.email me@razeen.me

// @license.name Apache 2.0
// @license.url http://www.apache.org/licenses/LICENSE-2.0.html

// @host 127.0.0.1:8080
// @BasePath /api/v1
func main() {
	r := gin.Default()
	r.GET("/someJSON", func(c *gin.Context) {
		//自定义map
		data := map[string]interface{}{
			"name":    "小王子",
			"message": "helloworld",
			"age":     18,
		}
		c.JSON(http.StatusOK, data)
	})
	r.Run()
}

image-20220207125045184

生成接口文档

输入;swag init
输入以上命令后,项目根目录下会自动生成一个docs文件夹,里面有3个文件夹(爆红的原因是是需要一些额外的依赖)

image-20220207131127331

image-20220207125218880

4.引入gin-swagger渲染文档数据

在main函数的import里新加两个依赖:
gs "github.com/swaggo/gin-swagger"
	"github.com/swaggo/gin-swagger/swaggerFiles"
	
并注册swagger api相关路由,再写下如下代码	
r.GET("/swagger/*any", gs.WrapHandler(swaggerFiles.Handler))

终端里输入 go mod tidy 
package main

import (
	"github.com/gin-gonic/gin"
	gs "github.com/swaggo/gin-swagger"
	"github.com/swaggo/gin-swagger/swaggerFiles"
	"net/http"
)

// @title Swagger Example API
// @version 1.0
// @description This is a sample server celler server.
// @termsOfService https://razeen.me

// @contact.name Razeen
// @contact.url https://razeen.me
// @contact.email me@razeen.me

// @license.name Apache 2.0
// @license.url http://www.apache.org/licenses/LICENSE-2.0.html

// @host 127.0.0.1:8080
// @BasePath /api/v1
func main() {
	r := gin.Default()
	r.GET("/swagger/*any", gs.WrapHandler(swaggerFiles.Handler))
	r.GET("/someJSON", func(c *gin.Context) {
		//自定义map
		data := map[string]interface{}{
			"name":    "小王子",
			"message": "helloworld",
			"age":     18,
		}
		c.JSON(http.StatusOK, data)
	})
	r.Run()
}

5.查看文档

把你的项目程序运行起来,打开浏览器访问http://localhost:8080/swagger/index.html就能看到Swagger 2.0 Api文档了。

image-20220207135504662

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

GoGo在努力

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值