Gin-Swagger的使用

简介: 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看到接口文档了

相关文章
|
5月前
|
JSON 中间件 数据格式
Gin框架学习笔记(六)——gin中的日志使用
Gin框架学习笔记(六)——gin中的日志使用
160 0
|
5月前
|
JSON 前端开发 Java
|
5月前
|
前端开发 中间件 关系型数据库
|
6月前
|
JSON 数据库 数据格式
Swagger 中 allOf 的使用技巧
Swagger 提供了一个名为 allOf 的特性,它是通过扩展已有的数据模型来构造更为复杂的数据结构的有效手段。这一特性主要用于数据模型的继承及属性的组合,有效减少了代码重复,同时增强了代码的可维护性与清晰度。访问 Swagger 官方网站可以获得更多关于Swagger的详细信息。
|
6月前
|
XML JSON 人工智能
探索Gin框架:Golang Gin框架请求参数的获取
探索Gin框架:Golang Gin框架请求参数的获取
|
6月前
|
存储 人工智能 Go
探索Gin框架:Golang使用Gin完成文件上传
探索Gin框架:Golang使用Gin完成文件上传
|
6月前
|
存储 API Go
Hertz 整合swagger
Hertz 整合swagger
86 0
|
API Go 网络架构
Kratos 大乱炖 —— 整合其他Web框架:Gin、FastHttp、Hertz
Kratos默认的RPC框架使用的是gRPC,支持REST和protobuf两种通讯协议。其API都是使用protobuf定义的,REST协议是通过[grpc-gateway](https://github.com/grpc-ecosystem/grpc-gateway)转译实现的。使用protobuf定义API是具有极大优点的,具有很强的可读性、可维护性,以及工程性。工程再大,人员再多,也不会乱。 一切看起来都是很美好的。那么,问题来了,我们现在使用的是其他的Web框架,迁移就会有成本,有风险,不可能一下子就把历史存在的代码一口气转换过来到Kratos框架。那我可以在Kratos中整合其他
871 0
|
JSON 中间件 数据库连接
gin 框架中的 gin.Context
Context 是 gin 中最重要的部分。 例如,它允许我们在中间件之间传递变量、管理流程、验证请求的 JSON 并呈现 JSON 响应。Context 中封装了原生的 Go HTTP 请求和响应对象,同时还提供了一些方法,用于获取请求和响应的信息、设置响应头、设置响应状态码等操作。
641 0
gin 框架中的 gin.Context
|
Go API
Golang:gin-gonic/gin一个用 Go (Golang) 编写的 HTTP Web 框架
Golang:gin-gonic/gin一个用 Go (Golang) 编写的 HTTP Web 框架
133 0
Golang:gin-gonic/gin一个用 Go (Golang) 编写的 HTTP Web 框架