goland之gin集成swagger

下载相关依赖

go get github.com/swaggo/swag/cmd/swag
go get -u github.com/swaggo/gin-swagger
go get -u github.com/swaggo/gin-swagger/swaggerFiles

在项目目录执行,生成文档

swag init

此时项目会生成文件夹
在这里插入图片描述

若执行swag init出现一下报错(本项目mac环境):

command not found

编辑.bash_profile文件

#在PATH环境变量添加:Users/ming/go/bin
#go get下载成功后swag命令在~/go/bin下
export PATH=$PATH:$MAVEN_HOME/bin:Users/ming/go/bin

使配置文件生效

 source .bash_profile 

项目代码

package main

import (
	"ginStudy/db"
	_ "ginStudy/docs"
	"github.com/gin-gonic/gin"
	ginSwagger "github.com/swaggo/gin-swagger"
	"github.com/swaggo/gin-swagger/swaggerFiles"
	"net/http"
)

//初始化连接数据库
func init() {
	db.InitDb()
}

func main() {
	// 1.创建路由
	r := gin.Default()
	// 2.绑定路由规则,执行的函数
	// gin.Context,封装了request和response
	/*r.GET("/user/selectById", func(c *gin.Context) {
		//指定默认值
		//http://localhost:8080/user 才会打印出来默认的值
		id := c.DefaultQuery("id", "")

		if len(id) > 0 {
			//字符串装int
			n, err := strconv.Atoi(id)
			if err != nil {
				fmt.Println(err)
			}
			c.JSON(200, gin.H{"message": "success", "status": 200, "data": user.SelectById(n)})
		}
		//c.JSON(500, gin.H{"message": "fail", "status": 500, "data": ""})
	})

	r.GET("/", func(c *gin.Context) {
		user.Insert("明", "13416908424", "13416908424")
		//响应json格式
		c.JSON(200, gin.H{"message": "success", "status": 200, "data": "some Json data"})
	})*/

	//登录
	r.POST("/login", login)
	//swagger访问
	r.GET("/swagger/*any", ginSwagger.WrapHandler(swaggerFiles.Handler))
	// 3.监听端口,Run("里面不指定端口号默认为8080")
	r.Run(":8888")
}

// @登录
// @Description login
// @Accept  json
// @Produce json
// @Param   phone     path    string     true        "phone"
// @Param   password     path    string     true        "password"
// @Success 200 {string} string    "ok"
// @Router /login [post]
func login(c *gin.Context) {
	phone := c.PostForm("phone")
	password := c.PostForm("password")
	c.String(http.StatusOK, "Hello world "+phone+"_"+password)
}

访问“http://localhost:8888/swagger/index.html”

在这里插入图片描述
若访问swagger时出现“Failed to load spec…,则在import引入以下包即可”
在这里插入图片描述

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Go 1.17 中,你可以使用 embed 包将静态文件嵌入到可执行文件中,因此可以将 Swagger UI 嵌入到 Go Web 项目中,而不需要单独部署 Swagger UI。 以下是在 Goland 项目中使用 Swagger 的步骤: 1. 安装 Swagger 相关依赖:在项目中添加 `github.com/swaggo/swag` 和 `github.com/swaggo/gin-swagger` 两个依赖库,可以使用以下命令: ``` go get -u github.com/swaggo/swag go get -u github.com/swaggo/gin-swagger go get -u github.com/swaggo/gin-swagger/swaggerFiles ``` 2. 在项目中添加 Swagger 注释:在需要生成 Swagger 文档的接口上添加注释,例如: ``` // @Summary 获取用户信息 // @Description 根据用户ID获取用户信息 // @Tags 用户管理 // @Produce json // @Param id path int true "用户ID" // @Success 200 {object} UserResponse // @Failure 400 {string} string "请求参数错误" // @Router /users/{id} [get] func GetUserByID(c *gin.Context) { // ... } ``` 3. 生成 Swagger 文档:在项目根目录下执行以下命令,生成 Swagger 文档: ``` swag init ``` 该命令会在项目中生成一个 `docs` 目录,其中包含了 Swagger 文档的 JSON 文件和 HTML 文件。 4. 在项目中嵌入 Swagger UI:在项目中添加一个 `swagger` 目录,并将 Swagger UI 的静态文件拷贝到该目录中。可以从 Swagger 官网(https://swagger.io/tools/swagger-ui/)下载最新的 Swagger UI 版本。 ``` ├── main.go ├── go.mod ├── go.sum ├── docs │ ├── docs.go │ ├── swagger.json │ └── swagger.yaml └── swagger ├── index.html ├── swagger-ui-standalone-preset.js ├── swagger-ui-standalone-preset.js.map ├── swagger-ui.css ├── swagger-ui.css.map ├── swagger-ui.js ├── swagger-ui.js.map └── swagger-ui.min.js ``` 5. 在项目中添加 Swagger UI 的路由:在项目中添加一个路由,将 Swagger UI 的 HTML 文件和静态文件提供给用户访问,例如: ``` router.GET("/swagger/*any", gin.WrapH(http.FileServer(http.Dir("./swagger")))) ``` 这样,用户可以通过访问 `/swagger/index.html` 来查看 Swagger 文档。 6. 启动项目并访问 Swagger UI:在 Goland 中启动项目,然后在浏览器中访问 `http://localhost:8080/swagger/index.html`,即可访问 Swagger UI 并查看文档。 需要注意的是,这种方式虽然可以将 Swagger UI 嵌入到可执行文件中,但是每次修改 Swagger UI 后都需要重新编译可执行文件,因此不建议在生产环境中使用。如果你需要在生产环境中使用 Swagger UI,建议单独部署一个 Swagger UI 服务。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值