码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Gin-Swagger的使用


    文章目录

    • 前言
    • 一、准备工作
    • 二、添加注释
    • 四、生成docs文件
    • 三、注册路由
    • 总结


    前言

    在写前后端分离的后端项目的时候,我们常常写后端程序返回的大多都是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() {
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 接口函数中
    // @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) {
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

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

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

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

    四、生成docs文件

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

    三、注册路由

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

    总结

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

  • 相关阅读:
    2023最新SSM计算机毕业设计选题大全(附源码+LW)之java智慧小区综合管理平台q1033
    猿创征文|前端之行,任重道远(来自大三学长的万字自述)
    IDEA本机连接远程TDengine不成功,终于配置成功
    【Java八股40天-Day3】 集合类1
    我赢助手之爆款内容创作:爆款内容的四大特性,梳理下自己的账号吧?
    UE4中抛体物理模拟UProjectileMovementComponent
    字节迎来新 CFO,或重启上市;马斯克以 440 亿美元收购 Twitter;FFmpeg 支持 JPEG-XL|极客头条
    Python开发环境搭建
    Visual Studio 2022 + OpenCV 4.5.2 安装与配置教程
    Android 裁剪摄像头预览窗口-SurfaceView
  • 原文地址:https://blog.csdn.net/qq_51898139/article/details/126463726
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号