Spring Boot Swagger2自動生成接口文檔和Mock模擬數據

一、簡介

在當下這個前后端分離的技術趨勢下,前端工程師過度依賴后端工程師的接口和數據,給開發帶來了兩大問題:

問題一、后端接口查看難:要怎么調用?參數怎么傳遞?有幾個參數?參數都代表什么含義?問題二、返回數據操作難:數據返回不對或者不夠怎么辦?怎么才能靈活的操作數據?

這是很多公司前后端分離之后帶來的困擾,那怎么來解決這些問題?

問題一的一般解決方案:后端團隊共同維護一個在線文檔,每次改接口再去改對應的文檔,但難免會遺漏,花的大力氣但卻效果平平。

問題二的一般解決方案:自己搭建一個Mock服務器,然后一個接口一個接口手動去錄規則,還是一個費力的體力活。

那有沒有最優的解決方案,來解決以上兩個問題呢?答案是肯定的,那就是將要登場的“Swagger”和“Easy Mock”。

1.1 Swagger介紹

Swagger是全球最流行的接口文檔自動生成和測試的框架,幾乎支持所有的開發語言。

Swagger官網地址:https://swagger.io/

1.2 Easy Mock介紹

Easy Mock是一個可視化,并且能快速生成 模擬數據的持久化服務。

Easy Mock能一鍵導入Swagger所有接口,省去了手動錄制接口的麻煩,而且能夠完美的適配Swagger中的代碼注釋,可謂開發利器。

Easy Mock數據是保存在云端的,而且可以創建團隊項目,可以真正的實現前端脫離后端進行項目開發。

接下來一起來看看怎么在項目中集成Swagger和Easy Mock吧。

1.3 開發環境

JDK 8Spring Boot 2.0.4Swagger 2.9.2IDEA 2018.2

二、Swagger集成

本文介紹的Swagger是基于Spring Boot框架的,一起來看具體的實現步驟。

2.1 添加依賴

配置pom.xml,添加如下代碼:

image

其中:

springfox-swagger2 用于JSON API文檔的生成;springfox-swagger-ui 用于文檔界面展示。

更多版本請訪問:

springfox-swagger2:http://mvnrepository.com/arti...

springfox-swagger-ui:http://mvnrepository.com/arti...

2.2 注冊Swagger

在源碼的根目錄也就是Appliction.java的同級目錄,創建Java類“SwaggerConfig.java”(命名無所謂),代碼如下:

image

其中“@ConditionalOnExpression”為Spring的注解,用戶是否實例化本類,用于是否啟用Swagger的判斷(生產環境需要屏蔽Swagger)。

2.3 生產環境禁用Swagger

是否啟用Swagger是在application.properties文件里配置的,配置如下:

swagger.enable=true

生產環境禁用,設置為false即可。

2.4 添加文檔注釋

完成以上三個步驟,已經完成了Spring Boot對Swagger的集成,但是文檔不夠友好,比如類、接口的中文說明、參數的說明,是沒有的,需要在代碼中完成。

如下代碼:

image

寫完代碼運行項目,在瀏覽器輸入:http://localhost:8080/swagger-ui.html 查看添加注釋的效果,如下圖:

image

其中@Api是用來描述類的,@ApiOperation是用來描述方法的,@ApiImplicitParam是用來描述參數的,更多注解說明請看下文。

示例源碼下載:https://github.com/vipstone/s...

三、Swagger文檔注解

我們現在已經對Swagger有了初步的認識,本節重點來看Swagger注解的使用。

Swagger注解的作用是給接口添加注釋的。

3.1 @Api 類注釋

@Api:用來描述類的,屬性如下:

tags 描述類的用途value 對顯示而言沒有任何用途可以不用設置

代碼示例:

@Api(tags = "文章接口")

3.2 @ApiOperation 方法注釋

@ApiOperation:用來描述方法的,屬性如下:

value 方法的描述notes 方法備注說明

代碼示例:

@ApiOperation(value = "獲取所有文章", notes = "查詢分頁數據")

效果如下圖:

image

3.3 @ApiImplicitParams 參數注釋

@ApiImplicitParams:描述多參數

@ApiImplicitParam:描述單參數

屬性如下:

name 參數value 參數的描述required 是否必傳paramType 參數存放位置:header、query、path(resuful接口)、body、formdataType 參數類型defaultValue 參數默認值

代碼示例:

image

效果如下圖:

image

3.4 @ApiModel 實體對象描述

@ApiModel:實體類名描述,屬性如下:

description 類描述

@ApiModelProperty:字段描述,屬性如下:

value 字段描述

示例如下:

image

四、Easy Mock使用

Easy Mock是在線的Mock(模擬)服務器,注冊賬號即可使用,數據存儲云端,使用簡單不需要在本地進行任何配置,具體操作步驟如下文。

4.1 注冊賬號

瀏覽器輸入:https://easy-mock.com/login 注冊賬號

4.2 配置Easy Mock項目

進入管理頁面之后,點擊演示個人演示項目(默認創建的可以直接拿來用),如下圖:

image

進入接口列表,點擊設置=>點擊Swagger Docs API選擇Upload(本地文件上傳),如下圖:

image

4.3 導出Swagger接口

瀏覽器訪問:http://localhost:8080/v2/api-docs 就看到項目的所有接口JSON格式的,右鍵另存為文件,如下圖:

image

繼續4.2的操作,上傳剛剛保存的JSON文件到Easy Mock。

4.4 更新接口

保存完JSON數據之后就返回到項目的設置頁了,這個時候點擊“同步Swagger”就看到所有接口了。如下圖:

image

到此為所有的接口已經導入了,可以點擊接口列表右側的復制按鈕,進行愉快的調用了。

這個時候就可以完全脫離后端了,點擊接口詳情,可以看出Easy Mock完美識別了Swagger注釋也有了,如下圖:

image

4.5 修改數據

接口的調用沒問題,接下來就是修改操作數據了,點擊右側的相應接口的修改按鈕,如下圖:

image

進入編輯頁面,你現在編輯的數據就是接口要返回的數據,數據是JSON格式的,并且是在線保存云端,無須擔心數據丟失,如下圖:

image

編輯完直接點擊更新接口即可,注意編輯頁面還有一個預覽按鈕,點入可以模擬請求,這下連Postman都省了,效果如下:

image

五、總結

到此為止所有內容已經演示完了,我們解決前后端分離帶來接口管理難、數據操作難的問題。自動生成接口文檔、一鍵模擬數據,讓我們不再依賴后端,只專注前端的業務,等后端把接口寫完之后,再進行聯合調試就可以了,這樣我們就不費吹灰之力搞定了所有難題,并且靈活的配置讓我們可以不影響和污染生產環境,生產環境設置禁用Swagger即可,并且有了預覽功能之后我們甚至連Postman都省了。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
禁止轉載,如需轉載請通過簡信或評論聯系作者。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,837評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,196評論 3 414
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 175,688評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,654評論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,456評論 6 406
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 54,955評論 1 321
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,044評論 3 440
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,195評論 0 287
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,725評論 1 333
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,608評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,802評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,318評論 5 358
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,048評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,422評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,673評論 1 281
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,424評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,762評論 2 372

推薦閱讀更多精彩內容