当前位置: 首页 > news >正文

Golang 项目中使用 Swagger

Golang 项目中使用 Swagger

在日常的 Go 项目开发中,接口文档的维护往往是一件麻烦事。手动写文档不仅费时,还容易和实际代码脱节。Swagger 提供了一种优雅的解决方案:通过注解自动生成接口文档,并且可以在 Swagger UI 中直接调试接口。

本文将结合实际代码,介绍如何在 Golang 项目中集成 Swagger,并详细说明常见注解的用法。


一、初始化 Swagger 文档

首先安装 swag 工具:

go install github.com/swaggo/swag/cmd/swag@latest

在项目根目录执行:

# 在当前目录 docs 文件夹生成 docs.go、swagger.json、swagger.yaml 三个文件
swag init -g ./cmd/server/main.go

这样就会在 docs 文件夹下生成 Swagger 文档相关文件。


二、项目中集成 Swagger

server 层中注册 Swagger 路由:

// swagger doc
docs.SwaggerInfo.BasePath = "/v1"
s.GET("/swagger/*any", ginSwagger.WrapHandler(swaggerfiles.Handler,ginSwagger.DefaultModelsExpandDepth(-1),ginSwagger.PersistAuthorization(true),
))

model 层定义请求参数时,可以通过 example 提供示例值,方便前端在 Swagger UI 中测试:

type RegisterRequest struct {Email    string `json:"email" binding:"required" example:"1234@gmail.com"`Password string `json:"password" binding:"required" example:"123456"`
}

handler 层为接口添加注解:

// Register godoc
// @Summary 用户注册
// @Description 目前只支持邮箱登录
// @Tags 用户模块
// @Accept json
// @Produce json
// @Param request body v1.RegisterRequest true "params"
// @Success 200 {object} v1.Response
// @Router /register [post]
func (h *UserHandler) Register(ctx *gin.Context) {// 业务逻辑省略
}

三、常见 Swagger 注解说明

注解作用示例
@Summary接口简要说明// @Summary 获取用户信息
@Description接口详细描述// @Description 根据用户ID获取用户详细信息
@Tags接口分类// @Tags 用户管理, 基础功能
@Accept接收的请求类型// @Accept application/json
@Produce返回的响应类型// @Produce application/json
@Param请求参数说明// @Param id path int true "用户ID"
@Success成功响应// @Success 200 {object} model.User "用户信息"
@Failure失败响应// @Failure 404 {object} errcode.Error "用户不存在"
@Router路由与方法// @Router /users/{id} [GET]
@Deprecated标记接口废弃// @Deprecated
@Since标记接口版本// @Since v1.0.0

四、@Param 的扩展用法

@Param 支持更多属性,例如:

// @Param page query int false "页码" default(1) min(1)
// @Param status query string false "状态" enum(active,inactive)
  • default:默认值
  • enum:枚举值
  • min/max:数值范围
  • format:格式(如 date-time

五、完整示例

// @Summary 获取用户信息
// @Description 根据用户ID获取用户详细信息
// @Tags 用户管理
// @Produce application/json
// @Param id path int true "用户ID"
// @Success 200 {object} model.User "用户信息"
// @Failure 404 {object} errcode.Error "用户不存在"
// @Router /users/{id} [GET]
func GetUser(c *gin.Context) {// 实现逻辑
}

六、常见问题 FAQ

Q1:Swagger UI 无法访问怎么办?
检查是否正确注册了路由,例如:

r.GET("/swagger/*any", ginSwagger.WrapHandler(swaggerfiles.Handler))

然后访问 http://localhost:8080/swagger/index.html


Q2:如何自定义文档标题和描述?
docs/docs.go 中修改 SwaggerInfo

docs.SwaggerInfo.Title = "我的项目 API 文档"
docs.SwaggerInfo.Description = "这是一个示例项目的接口文档"
docs.SwaggerInfo.Version = "1.0"

Q3:修改注解后文档没有更新?
需要重新执行:

swag init -g ./cmd/server/main.go

Q4:如何隐藏某些接口?
在注释中添加:

// @Router /internal [get]
// @Summary 内部接口
// @Hidden

七、注意事项

  1. @Param 的参数顺序必须严格遵循:name in type required description
  2. 结构体字段必须导出(首字母大写),否则 Swagger 无法解析。
  3. 不同工具(如 swaggogo-swagger)对注解支持略有差异,需参考对应文档。
  4. 每次修改注解后,需要重新执行 swag init 生成文档。

八、总结

通过合理使用 Swagger 注解,可以让 Go 项目的接口文档 自动化生成,不仅减少了手动维护的成本,还能在 Swagger UI 中直接调试接口,极大提升开发效率。

如果你正在做一个中大型项目,强烈建议在项目初期就集成 Swagger,这样后续的接口协作和维护会轻松很多。

http://www.dtcms.com/a/474849.html

相关文章:

  • 电子科技东莞网站建设百度经验实用生活指南
  • 网站私信界面站长之家seo查找
  • 领略算法真谛:求组合数
  • 企业网站建设费用会计科目哪些网站可以免费看剧
  • 自己做单词卡的网站是什么广州市外贸网站建设品牌
  • 【强化学习】#10 Actor-Critic:从QAC到A3C/A2C
  • 存储栈学习笔记
  • 廊坊网站快速排名优化域名更换网站
  • 个人网站制作程序南昌地宝网租房信息网
  • 一流的龙岗网站设计内网建设网站
  • 大连网站建设服务东莞营销网站建设价格
  • 外贸网站做多少钱的4399影视在线观看免费高清
  • 网站层级关系装修平台网站有哪些
  • 【完整源码+数据集+部署教程】 落叶植物叶片分类系统源码和数据集:改进yolo11-LVMB
  • 公司网站宣传设计方案本地最新招聘信息
  • 茶叶网站flash模板免费下载wordpress开发的网站有哪些
  • wordpress ajax 注册个人做seo怎么赚钱
  • seata原理源码分析(二)事务模式-TCC(一) 织入拦截器,rpc,资源分析
  • 网站建设创意广告苏州北京网站建设
  • TwinCAT3配置OPC UA Server过程总结
  • 做网站需要用什么软件百度商店应用市场
  • 以Copilot重构CRUD流程为例
  • 网站备案证书放到哪里网站需要服务器
  • 【网络工程师】企业网络骨干链路冗余与环路避免实践
  • MATLAB双缝干涉实验模拟程序
  • 做网站现在用什么语言长沙seo网络优化
  • 创建对象内存分析
  • linux学习——总结
  • 上海网站搜索引擎优化如何搭建网站建设环境
  • 词根学习笔记 | Ag系列