go使用swagger生成接口文檔

  1. 安裝swag 工具
    go get -u github.com/swaggo/swag/cmd/swag
  2. 在入口文件寫上項(xiàng)目的簡(jiǎn)介
package main

import (
    "flag"
    "open-api/internal/app/fund"
)

// @title 這里寫標(biāo)題`
// @version 1.0`
// @description 這里寫描述信息`
// @termsOfService [http://swagger.io/terms/](http://swagger.io/terms/)`
// @contact.name 這里寫聯(lián)系人信息`
// @contact.url [http://www.swagger.io/support](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](http://www.apache.org/licenses/LICENSE-2.0.html)`
// @host 這里寫接口服務(wù)的host`
// @BasePath 這里寫base path`

func main() {
    var configPath string
    flag.StringVar(&configPath, "config", "./configs", "config path")
    flag.Parse()
    fund.Run(configPath)
}
  1. 在你代碼中處理請(qǐng)求的接口函數(shù)(通常位于controller層)按如下方式寫上注釋:
// @Summary 支付列表
// @Description 獲取支付列表
// @Accept  json
// @Produce  json
// @param Authorization header string true "驗(yàn)證參數(shù)Bearer和token空格拼接"
// @Param  body body st.PaySearch true "交款查詢參數(shù)"
// @Success 200 {object} response.Response{data=st.PayListResponse}
// @Failure 500 {object} response.Response
// @Router /app/pay/list [post]
func PayList(ctx *gin.Context) {
    var (
        paySearch st.PaySearch
        data      []st.PayListResponse
        err       error
    )
    if err := ctx.Bind(&paySearch); err != nil {
        response.Failed(ctx, response.InvalidParams, response.GetMsg(response.InvalidParams), data, err)
        return
    }
    data, err = logic.GetPayListNew(p)

    if err != nil {
        response.Failed(ctx, response.Error, response.GetMsg(response.Error), data, err)
        return
    }
    response.Successed(ctx, response.Success, response.GetMsg(response.Success), data)
}
  1. 上面注釋中參數(shù)類型使用了object污淋,st.PaySearch st.PayListResponse response.Response具體定義如下:
type Response struct {
    Code int         `json:"code"`
    Msg  string      `json:"msg"`
    Data interface{} `json:"data"`
}

type PayListResponse struct {
    HouseBase
    Id                 int             `json:"id"`
    Name               string          `json:"name"`
    PayAmount          decimal.Decimal `json:"pay_amount"`
    PayArea            decimal.Decimal `json:"pay_area"`
    BankAccountingTime TimeShowDay     `json:"bank_accounting_time"`
    BankName           string          `json:"bank_name"`
    AccountCode        string          `json:"account_code"`
    BankCode           string          `json:"bank_code"`
}

type PaySearch struct {
    Phone  string `form:"phone" binding:"required,phoneValid"`
    Status string `form:"status" binding:"required,oneof='0' '1'"`
}
  1. 生成文檔
swag init -g cmd/main.go  // -g 指定main.go 的位置忍弛,  我這邊是在cmd文件中
此時(shí)目錄中多了docs
./docs
├── docs.go
├── swagger.json
└── swagger.yaml
image.png
  1. 引入gin-swagger渲染文檔數(shù)據(jù), 利用條件編譯來決定是否編譯swagger英上,因?yàn)榫€上運(yùn)行時(shí)弓乙,不需要swagger
image.png

doc_swag.go

// +build doc

package router

import (
    swaggerFiles "github.com/swaggo/files"
    ginSwagger "github.com/swaggo/gin-swagger"
)

func init() {
    swagHandler = ginSwagger.WrapHandler(swaggerFiles.Handler)
}

swag.go 目前是空的

router.go

package router

import (
    _ "open-api/docs"
    "open-api/internal/app/fund/controller"
    "open-api/internal/app/fund/middleware"
    validator2 "open-api/pkg/validator"

    "github.com/gin-gonic/gin/binding"
    "github.com/go-playground/validator/v10"

    "github.com/gin-gonic/gin"
)

var swagHandler gin.HandlerFunc

func InitRouter() *gin.Engine {
    r := gin.New()
    r.Use(gin.Logger())
    r.Use(gin.Recovery())
    r.Use(middleware.Cors())

    // 開啟swag
    if swagHandler != nil {
        r.GET("/swagger/*any", swagHandler)
    }

    if v, ok := binding.Validator.Engine().(*validator.Validate); ok {
        _ = v.RegisterValidation("phoneValid", validator2.PhoneValidHook)
    }
    return r
}
  1. 在goland中配置build參數(shù)危纫,以便本地調(diào)試
image.png

至此就完成了盗忱。 如有問題請(qǐng)私信我凌唬。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末缠劝,一起剝皮案震驚了整個(gè)濱河市沼溜,隨后出現(xiàn)的幾起案子平挑,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,284評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件通熄,死亡現(xiàn)場(chǎng)離奇詭異唆涝,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)唇辨,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,115評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門廊酣,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人赏枚,你說我怎么就攤上這事亡驰。” “怎么了饿幅?”我有些...
    開封第一講書人閱讀 164,614評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵凡辱,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我诫睬,道長(zhǎng)煞茫,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,671評(píng)論 1 293
  • 正文 為了忘掉前任摄凡,我火速辦了婚禮续徽,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘亲澡。我一直安慰自己钦扭,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,699評(píng)論 6 392
  • 文/花漫 我一把揭開白布床绪。 她就那樣靜靜地躺著客情,像睡著了一般。 火紅的嫁衣襯著肌膚如雪癞己。 梳的紋絲不亂的頭發(fā)上膀斋,一...
    開封第一講書人閱讀 51,562評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音痹雅,去河邊找鬼仰担。 笑死,一個(gè)胖子當(dāng)著我的面吹牛绩社,可吹牛的內(nèi)容都是我干的摔蓝。 我是一名探鬼主播,決...
    沈念sama閱讀 40,309評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼愉耙,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼贮尉!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起朴沿,我...
    開封第一講書人閱讀 39,223評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤猜谚,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體龄毡,經(jīng)...
    沈念sama閱讀 45,668評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡吠卷,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,859評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了沦零。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片祭隔。...
    茶點(diǎn)故事閱讀 39,981評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖路操,靈堂內(nèi)的尸體忽然破棺而出疾渴,到底是詐尸還是另有隱情,我是刑警寧澤屯仗,帶...
    沈念sama閱讀 35,705評(píng)論 5 347
  • 正文 年R本政府宣布搞坝,位于F島的核電站,受9級(jí)特大地震影響魁袜,放射性物質(zhì)發(fā)生泄漏桩撮。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,310評(píng)論 3 330
  • 文/蒙蒙 一峰弹、第九天 我趴在偏房一處隱蔽的房頂上張望店量。 院中可真熱鬧,春花似錦鞠呈、人聲如沸融师。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,904評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽旱爆。三九已至,卻和暖如春窘茁,著一層夾襖步出監(jiān)牢的瞬間怀伦,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,023評(píng)論 1 270
  • 我被黑心中介騙來泰國(guó)打工山林, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留空镜,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,146評(píng)論 3 370
  • 正文 我出身青樓捌朴,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親张抄。 傳聞我的和親對(duì)象是個(gè)殘疾皇子砂蔽,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,933評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容