gin-swagger

gin 中间件,利用 Swagger 2.0 自动生成 RESTful API 文档。「gin middleware to automatically generate RESTful API documentation with Swagger 2.0.」

Github星跟踪图

gin-swagger

gin middleware to automatically generate RESTful API documentation with Swagger 2.0.

Travis branch
Codecov branch
Go Report Card
GoDoc

Usage

Start using it

  1. Add comments to your API source code, See Declarative Comments Format.
  2. Download Swag for Go by using:
$ go get -u github.com/swaggo/swag/cmd/swag
  1. Run the Swag in your Go project root folder which contains main.go file, Swag will parse comments and generate required files(docs folder and docs/doc.go).
$ swag init
  1. Download gin-swagger by using:
$ go get -u github.com/swaggo/gin-swagger
$ go get -u github.com/swaggo/files

And import following in your code:

import "github.com/swaggo/gin-swagger" // gin-swagger middleware
import "github.com/swaggo/files" // swagger embed files

Canonical example:

package main

import (
	"github.com/gin-gonic/gin"
	swaggerFiles "github.com/swaggo/files"
	"github.com/swaggo/gin-swagger"
	
	_ "github.com/swaggo/gin-swagger/example/basic/docs" // docs is generated by Swag CLI, you have to import it.
)

// @title Swagger Example API
// @version 1.0
// @description This is a sample server Petstore server.
// @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

// @host petstore.swagger.io
// @BasePath /v2
func main() {
	r := gin.New()

	url := ginSwagger.URL("http://localhost:8080/swagger/doc.json") // The url pointing to API definition
	r.GET("/swagger/*any", ginSwagger.WrapHandler(swaggerFiles.Handler, url))

	r.Run()
}
  1. Run it, and browser to http://localhost:8080/swagger/index.html, you can see Swagger 2.0 Api documents.

swagger_index.html

  1. If you want to disable swagger when some environment variable is set, use DisablingWrapHandler

Example with disabling:

package main

import (
	"github.com/gin-gonic/gin"
	swaggerFiles "github.com/swaggo/files"
	"github.com/swaggo/gin-swagger"
    
	_ "./docs" // docs is generated by Swag CLI, you have to import it.
)

// @title Swagger Example API
// @version 1.0
// @description This is a sample server Petstore server.
// @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

// @host petstore.swagger.io
// @BasePath /v2
func main() {
	r := gin.New()
    
    // use ginSwagger middleware to 
	r.GET("/swagger/*any", ginSwagger.DisablingWrapHandler(swaggerFiles.Handler, "NAME_OF_ENV_VARIABLE"))

	r.Run()
}

Then, if you set envioment variable NAME_OF_ENV_VARIABLE to anything, /swagger/*any
will respond 404, just like when route unspecified.

主要指标

概览
名称与所有者xeipuuv/gojsonschema
主编程语言Go
编程语言Go (语言数: 1)
平台Linux, Mac, Windows
许可证
所有者活动
创建于2013-02-26 10:23:25
推送于2024-06-28 22:32:47
最后一次提交2020-10-26 18:00:38
发布数3
最新版本名称v1.2.0 (发布于 )
第一版名称v1.0 (发布于 )
用户参与
星数2.7k
关注者数39
派生数367
提交数500
已启用问题?
问题数212
打开的问题数107
拉请求数97
打开的拉请求数32
关闭的拉请求数40
项目设置
已启用Wiki?
已存档?
是复刻?
已锁定?
是镜像?
是私有?