Gin使用swagger生成接口文档的代码示例

 更新时间:2024年06月11日 08:25:33   作者:NanYan  
Swagger 是一个规范和完整的框架,用于生成、描述、调用和可视化 RESTful Web 服务,它使用 YAML 或 JSON 格式来定义 API 的结构,本文给大家介绍了Gin使用swagger生成接口文档的代码示例,需要的朋友可以参考下

什么是swagger

Swagger 是一个规范和完整的框架,用于生成、描述、调用和可视化 RESTful Web 服务。它使用 YAML 或 JSON 格式来定义 API 的结构,包括请求、响应、参数等信息。Swagger 的主要特点包括:

  • 规范性:Swagger 定义了一套 API 描述的标准,使得开发者可以以统一的方式描述 API。
  • 自动生成文档:Swagger 可以自动生成 API 文档,使得开发者和用户可以快速了解 API 的使用方法。
  • 交互式文档:Swagger 提供了一个交互式的用户界面,用户可以直接在文档中尝试 API 调用。
  • 代码生成:Swagger 可以根据 API 描述自动生成服务器和客户端的代码,节省开发时间。
  • 社区支持:Swagger 有广泛的社区支持,许多开发者和公司都在使用它来构建和管理他们的 API。
  • 工具链集成:Swagger 可以与许多开发工具和平台集成,如 Spring Boot、.NET Core、Node.js 等。
  • 版本控制:Swagger 支持 API 的版本控制,使得 API 的迭代更加灵活。

Swagger 现在通常与 OpenAPI Specification (OAS) 结合使用,后者是一个由 Linux 基金会支持的开放标准,用于描述 API。Swagger 的工具和生态系统现在也支持 OAS。

swagger安装

$ go get -u github.com/swaggo/swag/cmd/swag 
# 1.16 及以上版本 
$ go install github.com/swaggo/swag/cmd/swag@latest

gin-swagger

安装

go get -u github.com/swaggo/gin-swagger

使用

想要使用gin-swagger为你的代码自动生成接口文档,一般需要下面三个步骤:

  • 按照swagger要求给接口代码添加声明式注释,具体参照声明式注释格式。
  • 使用swag工具扫描代码自动生成API接口文档数据
  • 使用gin-swagger渲染在线接口文档页面

添加注释

在程序入口main函数上以注释的方式写下项目相关介绍信息。

package main

// @title 这里写标题
// @version 1.0
// @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
func main() {
	r := gin.New()

	// liwenzhou.com ...

	r.Run()
}

在你代码中处理请求的接口函数(通常位于controller层)按如下方式写上注释:

// GetCommunityHandler 获取社区列表
// @Summary 获取社区列表
// @Description 获取社区列表
// @Tags 社区列表
// @Accept json
// @Produce json
// @Param Authorization header string true "Bearer 用户令牌"
// @Success 200 {object} models.GetCommunityListParams "成功"
// @Router /community [get]
// @Request Body models.GetCommunityListParams "社区列表"
func GetCommunityHandler(c *gin.Context) {
    // 获取社区列表 (Community_id, Community_name) list
    list, err := communityLg.GetCommunityList()
    if err != nil {
       api.ResponseErrorWithMsg(c, 200, "获取社区列表失败")
       return
    }
    api.ResponseSuccess(c, list)
}

生成接口文档数据

在项目根目录中运行命令:swag init,将会解析注解并生成所需的文件(doc文件夹和docs.go,swagger.json,swagger.yaml

swag init

执行完命令后,会生成以下文件

./docs
├── docs.go
├── swagger.json
└── swagger.yaml

然后在项目代码中注册路由的地方按如下方式引入gin-swagger相关内容:

import (

	_ "project/docs"  // 千万不要忘了导入把你上一步生成的docs

	gs "github.com/swaggo/gin-swagger"
	"github.com/swaggo/gin-swagger/swaggerFiles"

	"github.com/gin-gonic/gin"
)

注册swagger api相关路由

r.GET("/swagger/*any", gs.WrapHandler(swaggerFiles.Handler))

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

gin-swagger同时还提供了DisablingWrapHandler函数,方便我们通过设置某些环境变量来禁用Swagger。例如:

r.GET("/swagger/*any", gs.DisablingWrapHandler(swaggerFiles.Handler, "NAME_OF_ENV_VARIABLE"))

可能遇到的问题

在我使用时发现在执行swag init时,会出现找不到gorm.Model的情况。

解决方案:

在命令行加上 --parseDependency --parseInternal

swag init --parseDependency --parseInternal

到此这篇关于Gin使用swagger生成接口文档的代码示例的文章就介绍到这了,更多相关Gin swagger接口文档内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Golang两行代码实现发送钉钉机器人消息

    Golang两行代码实现发送钉钉机器人消息

    创建一个钉钉机器人必须使用加签,本文通过Golang两行代码实现发送钉钉机器人消息,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧
    2021-12-12
  • GO 切片删除元素的三种方法

    GO 切片删除元素的三种方法

    本文主要介绍了GO 切片删除元素,根据要删除元素的位置有三种情况,分别是从开头位置删除、从中间位置删除和从尾部删除,具有一定的参考价值,感兴趣的可以了解一下
    2024-08-08
  • golang官方嵌入文件到可执行程序的示例详解

    golang官方嵌入文件到可执行程序的示例详解

    这篇文章主要介绍了golang官方嵌入文件到可执行程序,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-02-02
  • golang 获取字符串长度的案例

    golang 获取字符串长度的案例

    这篇文章主要介绍了golang 获取字符串长度的案例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12
  • go语言的四数相加等于指定数算法

    go语言的四数相加等于指定数算法

    这篇文章主要介绍了go语言的四数相加等于指定数算法的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-04-04
  • 如何使用Golang创建与读取Excel文件

    如何使用Golang创建与读取Excel文件

    我最近工作忙于作图,图表,需要自己准备数据源,所以经常和Excel打交道,下面这篇文章主要给大家介绍了关于如何使用Golang创建与读取Excel文件的相关资料,需要的朋友可以参考下
    2022-07-07
  • golang使用jaeger进行链路追踪

    golang使用jaeger进行链路追踪

    链路追踪是指在分布式系统中,将一次请求的处理过程进行记录并聚合展示的一种方法,目的是将一次分布式请求的调用情况集中在一处展示,本文将介绍golang如何使用jaeger进行链路追踪,需要的朋友可以参考下
    2024-06-06
  • Golang在整洁架构基础上实现事务操作

    Golang在整洁架构基础上实现事务操作

    这篇文章在 go-kratos 官方的 layout 项目的整洁架构基础上,实现优雅的数据库事务操作,需要的朋友可以参考下
    2024-08-08
  • 详解使用Go添加Nginx代理的方法示例

    详解使用Go添加Nginx代理的方法示例

    这篇文章主要介绍了详解使用Go添加Nginx代理的方法示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-11-11
  • golang定时任务cron项目实操指南

    golang定时任务cron项目实操指南

    Go实现的cron 表达式的基本语法跟linux 中的 crontab基本是类似的,下面这篇文章主要给大家介绍了关于golang定时任务cron项目实操的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2022-12-12

最新评论