Gin-Swagger的使用


前言

在写前后端分离的后端项目的时候,我们常常写后端程序返回的大多都是restful API风格的JSON数据,

而Swagger本质上是一种用于描述使用JSON表示的RESTful API的接口描述语言,配合gin框架使用就可以自动生成一份接口文档包括自动文档,代码生成和测试用例生成。

一、准备工作

go get -u github.com/swaggo/swag/cmd/swag下载这个包方便我们使用swag命令

二、添加注释

注释一般添加在两个地方,一个是main函数里,另外就是添加到api接口函数里

  • main函数中
package main

// @title 这里写标题
// @version 这里写版本号
// @description 这里写描述信息
// @termsOfService http://swagger.io/terms/

// @contact.name 这里写联系人信息
// @contact.url http://www.swagger.io/support
// @contact.email support@swagger.io

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

// @host 这里写接口服务的host
// @BasePath 这里写base path(eg:/api/v1)
func main() {
  • 接口函数中
// @Summary 升级版帖子列表接口
// @Description 可按社区按时间或分数排序查询帖子列表接口
// @Tags 帖子相关接口
// @Accept application/json
// @Produce application/json
// @Param Authorization header string false "Bearer 用户令牌"
// @Param object query models.ParamArtList(请求参数结构体) false "查询参数"
// @Security ApiKeyAuth
// @Success 200 {object} _ResponseArtList
// @Router /接口路由 [请求类型]
func GetArt(c *gin.Context) {

_ResponseArtList一般是在接口层再额外定义的用于swagger的结构体

// 文章列表接口数据信息
type _ResponseArticle struct {
	Code    int              `json:"code"`    //业务状态码
	Message string           `json:"message"` // 提示信息
	Data    *[]model.Article `json:"data"`    // 数据
}

如果还想添加其他注释可以看文档添加需要的注释:swagger注释

四、生成docs文件

注释添加完毕之后就应该在终端输入swag init这样项目中就会多一个docs文件
在这里插入图片描述

三、注册路由

然后再在router里面注册路由
r.GET("/swagger/*any", gs.WrapHandler(swaggerFiles.Handler))
注意要把docs文件导入router里

总结

这样项目启动就可以访问http://localhost:port/swagger/index.html看到接口文档了

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值