package main // @title 這里寫標題 // @version 1.0 // @description 這里寫描述信息 // @termsOfService http://swagger.io/terms/ // @contact.name 這里寫聯系人信息 // @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 這里寫接口服務的host // @BasePath 這里寫base path func main() { r := gin.New() // liwenzhou.com ... r.Run
// GetPostListHandler2 升級版帖子列表接口 // @Summary 升級版帖子列表接口 // @Description 可按社區按時間或分數排序查詢帖子列表接口 // @Tags 帖子相關接口 // @Accept application/json // @Produce application/json // @Param Authorization header string false "Bearer 用戶令牌" // @Param object query models.ParamPostList false "查詢參數" // @Security ApiKeyAuth // @Success 200 {object} _ResponsePostList // @Router /posts2 [get] func GetPostListHandler2(c *gin.Context) { // GET請求參數(query string):/api/v1/posts2?page=1&size=10&order=time // 初始化結構體時指定初始參數 p := &models.ParamPostList{ Page: 1, Size: 10, Order: models.OrderTime, } if err := c.ShouldBindQuery(p); err != nil { zap.L().Error("GetPostListHandler2 with invalid params", zap.Error(err)) ResponseError(c, CodeInvalidParam) return } data, err := logic.GetPostListNew(p) // 獲取數據 if err != nil { zap.L().Error("logic.GetPostList() failed", zap.Error(err)) ResponseError(c, CodeServerBusy) return } ResponseSuccess(c, data) // 返回響應 }
// bluebell/models/params.go // ParamPostList 獲取帖子列表query string參數 type ParamPostList struct { CommunityID int64 `json:"community_id" form:"community_id"` // 可以為空 Page int64 `json:"page" form:"page" example:"1"` // 頁碼 Size int64 `json:"size" form:"size" example:"10"` // 每頁數據量 Order string `json:"order" form:"order" example:"score"` // 排序依據 }
// bluebell/controller/docs_models.go // _ResponsePostList 帖子列表接口響應數據 type _ResponsePostList struct { Code ResCode `json:"code"` // 業務響應狀態碼 Message string `json:"message"` // 提示信息 Data []*models.ApiPostDetail `json:"data"` // 數據 }
go get -u github.com/swaggo/swag/cmd/swag
swag init
./docs ├── docs.go ├── swagger.json └── swagger.yaml
import ( // liwenzhou.com ... _ "bluebell/docs" // 千萬不要忘了導入把你上一步生成的docs gs "github.com/swaggo/gin-swagger" "github.com/swaggo/gin-swagger/swaggerFiles" "github.com/gin-gonic/gin" )
r.GET("/swagger/*any", gs.WrapHandler(swaggerFiles.Handler))
gin-swagger
r.GET("/swagger/*any", gs.DisablingWrapHandler(swaggerFiles.Handler, "NAME_OF_ENV_VARIABLE"))