欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

Swagger與YApi的示例分析

這篇文章將為大家詳細講解有關(guān)Swagger與YApi的示例分析,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。

創(chuàng)新互聯(lián)長期為近1000家客戶提供的網(wǎng)站建設(shè)服務(wù),團隊從業(yè)經(jīng)驗10年,關(guān)注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為江川企業(yè)提供專業(yè)的成都網(wǎng)站設(shè)計、成都網(wǎng)站建設(shè),江川網(wǎng)站改版等技術(shù)服務(wù)。擁有10多年豐富建站經(jīng)驗和眾多成功案例,為您定制開發(fā)。

Swagger與YApi的示例分析

最近前端們一直反映Swagger看接口信息非常不爽,于是我花了倆小時把Swagger干掉,用上了傳說中更好用的YApi。

Swagger與YApi

其實我個人認為Swagger也沒啥不好的,后端集成起來方便快捷,就是UI不行,而且對于Java來說代碼的侵入性太高了。

Swagger與YApi的示例分析

swagger界面

YApi除了解決了這些問題之外還具有權(quán)限管理、團隊協(xié)作、自動化測試、支持OpenApi規(guī)范等等。

Swagger與YApi的示例分析

YApi界面

YApi區(qū)別于Swagger的最大不同就是YApi需要導入文檔(雖然它也可以通過Swagger輪詢導入),而Swagger可以自動發(fā)現(xiàn)。

安裝這里就不細說了,官方文檔說的很清楚。你可以選擇命令行部署、可視化部署,也能使用Docker部署。

推薦內(nèi)網(wǎng)部署,畢竟大部分API文檔比較敏感。

文檔注釋

YApi的文檔解析基于Java注釋規(guī)范,沒有代碼侵入!但是這就要求我們要按照Javadoc的規(guī)范進行書寫文檔注釋,這是使用YApi的前提。一個接口文檔分為以下幾個部分。

接口類注釋

接口類的注釋,下面是基本的格式。第一行會作為菜單展示,盡量短小精悍;第二行是接口的描述,用來描述接口的作用和細節(jié)。

/**  * 接口分類名稱  * <p>  * 接口備注/描述  *  * @author felord  * @since v1.0  */ @RestController @RequestMapping("/foo") public class FooController { // 省略 }

Swagger與YApi的示例分析

還有@module、@copyright什么的其實可以不寫。

參數(shù)注釋

入?yún)⒑统鰠⒌淖⑨?,配合JSR-303有奇效哦。

/**  * 賬戶基本信息  *   * @author felord  * @since v1.0  */ @Data public class UserInfoDetail {      /**      * 用戶名      *      * 配合JSR303注解聲明此字段的約束方式【必填】      */     @NotBlank     private String username;     /**      * 真實姓名      */     private String realName;     /**      * 手機號碼      */     private String phoneNumber;     /**      * 性別 -1 未知 0 女性 1 男性      *      * 使用@see來說明該字段的取值來源      * @see GenderType#value()      */     private Integer gender;     /**      * 昵稱      */     private String nickName;     /**      * 微信號      * 使用{@code Deprecated} 表示字典將來會廢棄      */     @Deprecated     private String wechatAccount;     /**      * 電子信箱      */     private String email; }

接口方法注釋

入?yún)閺碗s對象的話注釋用@link引用,@RequestBody會指定Content-Type為application/json。

/**  * 新增用戶信息  *  * @param userInfoDetail 用戶信息參數(shù) {@link UserInfoDetail}  * @return {@link Boolean}  */ @PostMapping("/bar") public boolean detail(@RequestBody UserInfoDetail userInfoDetail) {     return true; }

Swagger與YApi的示例分析

Post請求對應(yīng)的樣式

如果參數(shù)是原始類型類型或者String,可以這樣寫,@RequestParam有奇效。

/**  * 獲取用戶信息  *  * @param name 姓名  * @param age  年齡  * @return {@link UserInfoDetail}  */ @GetMapping("/sam") public UserInfoDetail detailBySamples(@RequestParam String name, Integer age) {     return new UserInfoDetail(); }

Swagger與YApi的示例分析

Get請求對應(yīng)的樣式

導入文檔

YApi支持Swagger、Postman、JSON等方式導入文檔。不過我個人更喜歡使用插件導入,Intellij  IDEA中推薦使用easy-yapi。導入的時候定位到對應(yīng)的Controller,使用快捷鍵Alt+Ins呼出快捷菜單。

Swagger與YApi的示例分析

呼出快捷菜單

選擇Export Yapi ,首次選擇會讓你輸入YApi的服務(wù)器地址,還會讓你輸入對應(yīng)項目的token字符串。

Swagger與YApi的示例分析

token 字符串

依次填入后,就會解析生成文檔并同步到Y(jié)Api服務(wù)器了,結(jié)果就是上面截圖中的樣子。然后你可以配置權(quán)限分配給組員使用了,如果有文檔更新重復上面的步驟即可,YApi提供了幾種策略,你可以選擇覆蓋也可以選擇不覆蓋。

關(guān)于Swagger與YApi的示例分析就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

本文題目:Swagger與YApi的示例分析
文章鏈接:http://aaarwkj.com/article28/gpjgjp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App設(shè)計、全網(wǎng)營銷推廣移動網(wǎng)站建設(shè)、關(guān)鍵詞優(yōu)化、電子商務(wù)、網(wǎng)站排名

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

小程序開發(fā)
18岁下禁止看的视频| 国内成人免费在线视频| 亚洲国产日韩伦中文字幕| 国产一级夫妻性生活欧美| 国产高清视频不卡在线| 亚洲激情欧美激情在线| 中文字幕一区二区三区网站| 亚洲精品一区二区激情| 国产精品一区二区综合亚洲| 午夜av在线毛片免费观看| 国产在线视频不卡一线路| 性感美女国产精品一区二区| 欧美一区二区日韩一区二区| 国产精品粗又长一区| 亚洲性感人妻系列网站| 亚洲精品日韩国产3区| 亚洲国产精品97视频| 久久精品国产成人综合| 午夜免费福利视频一区| 欧美a级黄片免费在线观看| 91国产在线视频免费观看| 亚洲av精二区三区四区| 加藤桃香中文字幕在线| 亚洲天堂毛片在线观看| 91深夜在线免费观看| 99久久免费热在线观看| 人妻少妇久久中文字幕久久| av国语对白在线观看| 国产丝袜美腿视频亚洲综合| 成人黄片在线免费播放| 日韩三级视频一区二区| 视频二区国产欧美日韩| 国产午夜草莓视频在线观看| 一区二区三区欧美日韩在线| 亚洲av成人在线观看| 可以直接看内射的视频| 欧美黑人少妇高潮喷水| 日本一区不卡二区高清| 亚洲成av人一区二区三区| 免费精品一区二区三区欧美| 一区二区不卡中文av|