go 集成swagger 在线接口文档

安装swaggo

Go 复制代码
go install github.com/swaggo/swag/cmd/swag@latest

编写swag

Go 复制代码
import (
	"github.com/gin-gonic/gin"
	"goWeb/internal/service"
	"goWeb/model/response"
)

// UserRouter 路由
func UserRouter(ctx *gin.RouterGroup) {
	ctx.GET("/login", login)
	ctx.POST("/addUser", addUser)
	ctx.GET("/delUser/:id", delUser)
	ctx.GET("/getUser", getUser)
	ctx.GET("/pageUser", pageUser)
}

// Login
//
//	@Description	Java学习Golang开发
//	@Tags			user接口
//	@Router			/user/login [get]
func login(ctx *gin.Context) {
	response.Success(ctx, service.Login())
}

// @Description	添加用户信息
// @Tags		user接口
// @Param		user	body		model.User	true	"用户实体"
// @Success		200		{string}	string			"success"
// @Failure		500		{string}	string			"fail"
// @Router			/user/addUser [post]
func addUser(ctx *gin.Context) {
	response.Success(ctx, service.AddUser(ctx))
}

// @Description	删除用户
// @Tags		user接口
// @Param		id	path		int	true	"用户id"
// @Router			/user/delUser/{id} [get]
func delUser(ctx *gin.Context) {
	service.DelUser(ctx)
	response.Ok(ctx)
}

// @Description	删除用户
// @Tags		user接口
// @Param		id	query		int	true	"用户id"
// @Router			/user/getUser [get]
func getUser(ctx *gin.Context) {
	response.Success(ctx, service.GetUser(ctx))
}

// @Description	分页查询用户数据
// @Tags		user接口
// @Param page query int false "当前页码"
// @Param pageSize query int false "每页数量"
// @Router			/user/pageUser [get]
func pageUser(ctx *gin.Context) {
	response.Success(ctx, service.PageUser(ctx))
}

启动类

Go 复制代码
import (
	swaggerFiles "github.com/swaggo/files"     // swagger embed files
	ginSwagger "github.com/swaggo/gin-swagger" // gin-swagger middleware
	_ "goWeb/docs"
)

//	@title			Swagger Example API
//	@version		1.0
//	@description	go web 框架gin集成swagger.
//	@termsOfService	http://swagger.io/terms/

//	@contact.name	API Support
//	@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

// @externalDocs.description	OpenAPI
// @externalDocs.url			https://swagger.io/resources/open-api/
func main() {}

初始化doc

复制代码
swag init

访问

http://127.0.0.1:8081/swagger/index.html#/

更多

请探索官网

swag package - github.com/swaggo/swag/v2 - Go Packages

相关推荐
一路向北⁢1 天前
Spring Boot 3 整合 SSE (Server-Sent Events) 企业级最佳实践(一)
java·spring boot·后端·sse·通信
测试_AI_一辰1 天前
项目实践笔记13:多用户事实碎片 Agent 的接口测试与约束设计
开发语言·人工智能·ai编程
风象南1 天前
JFR:Spring Boot 应用的性能诊断利器
java·spring boot·后端
爱吃山竹的大肚肚1 天前
微服务间通过Feign传输文件,处理MultipartFile类型
java·spring boot·后端·spring cloud·微服务
twj_one1 天前
java中23种设计模式
java·开发语言·设计模式
梵刹古音1 天前
【C语言】 跳转语句
c语言·开发语言·算法
阿猿收手吧!1 天前
【C++】C++模板特化:精准定制泛型逻辑
开发语言·c++·算法
ghie90901 天前
MATLAB中编写不平衡磁拉力方程
开发语言·matlab
weixin_452159551 天前
C++与Java性能对比
开发语言·c++·算法
会叫的恐龙1 天前
C++ 核心知识点汇总(第一日)(输入输出与变量、类型转换)
开发语言·c++