go语言 swagger 查询 json 字段注释

在Go语言中使用Swagger(例如通过swag工具和gin-gonic框架)来为API生成文档时,可以为查询参数以及JSON字段添加详细的注释。以下是如何在Go语言中为查询参数和JSON字段添加注释的具体步骤和示例代码。

  1. 引入必要的依赖

首先确保你的项目中包含了gin-gonic和swag等相关依赖。

复制代码
go get -u github.com/gin-gonic/gin
go get -u github.com/swaggo/gin-swagger
go get -u github.com/swaggo/files
go get -u github.com/swaggo/swag/cmd/swag
  1. 定义模型并添加注释

在Go语言中,可以使用结构体来表示数据模型,并在结构体字段上添加注释来描述这些字段。

示例代码

假设我们需要创建一个API端点,该端点接受查询参数name来过滤用户列表,并返回用户的详细信息

复制代码
package main

import (
	"github.com/gin-gonic/gin"
	"github.com/swaggo/gin-swagger"
	"github.com/swaggo/files"
	"github.com/swaggo/swag"
)

// User 用户模型
// swagger:model
type User struct {
	ID   int    `json:"id"`
	Name string `json:"name" example:"Alice"` // 添加example注释
	Age  int    `json:"age" example:"25"`
}

// QueryUsers godoc
// @Summary 获取用户列表
// @Description 获取所有用户的信息
// @Tags users
// @Produce json
// @Param name query string false "按名字过滤"
// @Success 200 {array} User
// @Router /users [get]
func QueryUsers(c *gin.Context) {
	name := c.Query("name")
	// 这里可以添加逻辑来根据name查询数据库
	users := []User{
		{ID: 1, Name: "Alice", Age: 25},
		{ID: 2, Name: "Bob", Age: 30},
	}
	c.JSON(200, users)
}

func main() {
	r := gin.Default()

	// 注册路由
	r.GET("/users", QueryUsers)

	// Swagger相关配置
	r.GET("/swagger/*any", ginSwagger.WrapHandler(swaggerFiles.Handler))

	// 生成Swagger文档
	swag.Init()
	r.Run(":8080")
}
相关推荐
于先生吖5 分钟前
前后端分离二手商城开发,质检登记、回收回款整套业务源码部署教程
java·开发语言·uni-app
codeejun8 分钟前
每日一Go-76(架构篇)|多集群部署 / 容灾 / Failover / Backup / 热迁移
开发语言·架构·golang
战族狼魂8 分钟前
从零构建企业级Hermes-Agent:复杂任务拆解、工具协同与安全落地实践
开发语言·人工智能·python
阿里嘎多学长30 分钟前
2026-06-08 GitHub 热点项目精选
开发语言·程序员·github·代码托管
程序员晨曦43 分钟前
Java 并发修仙传:ThreadLocal 从“闭关修炼”到“走火入魔”的救赎之路
java·开发语言
terry6001 小时前
从流畅交互到高可用:企讯通Qcaptcha滑动拼图的毫秒级响应与容灾设计
web安全·json·asp.net·信息与通信·数据库架构
李可以量化1 小时前
量化之MiniQMT 实战:一键读取通达信自选股并实时监控涨跌幅(附完整可运行代码)
开发语言·python·量化·qmt·ptrade
嘶哈哈哈1 小时前
嘉立创 EDA 入门实操笔记:从原理图到 PCB 布线、差分对、覆铜与 DRC 检查
开发语言·笔记·php
wgc2k1 小时前
Nest.js 基础-8-Hello,NestJS
开发语言·javascript·ecmascript
子午1 小时前
基于DeepSeek的酒店客房管理系统~Python+DeepSeek智能问答+Vue3+Web网站系统
开发语言·前端·python