Swagger“升級(jí)版”——knife4j

為什么選擇knife4j

頁(yè)面好看,我放兩張對(duì)比圖

image
image

圖一是knife4j的官網(wǎng)延届,圖二是swagger默認(rèn)的界面恨胚。如果覺(jué)得第二章比第一張好看的,可以不用往下看了徘键。

如何使用

貼一下knife4j的官網(wǎng):https://doc.xiaominfo.com/,里面有詳細(xì)的介紹遍蟋,這里只簡(jiǎn)單的介紹一下如何搭建吹害,先看一下簡(jiǎn)單的項(xiàng)目結(jié)構(gòu)

image
  1. 添加pom文件

    <!--整合Knife4j-->
    <dependency>
        <groupId>com.github.xiaoymin</groupId>
        <artifactId>knife4j-spring-boot-starter</artifactId>
        <version>3.0.3</version>
    </dependency>
    

    Knife4j里面集成了swagger的jar包,所以項(xiàng)目中有一個(gè)knife4j的jar包就能使用

  1. 添加配置文件

    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    import springfox.documentation.builders.ApiInfoBuilder;
    import springfox.documentation.builders.RequestHandlerSelectors;
    import springfox.documentation.service.ApiInfo;
    import springfox.documentation.service.Contact;
    import springfox.documentation.spi.DocumentationType;
    import springfox.documentation.spring.web.plugins.ApiSelectorBuilder;
    import springfox.documentation.spring.web.plugins.Docket;
    import springfox.documentation.swagger2.annotations.EnableSwagger2;
    
    /**
     * @Author nitric oxide
     * @Description
     * @Date 6:13 下午 2021/11/11
     */
    @EnableSwagger2
    @Configuration
    public class SwaggerConfig {
        @Bean(value = "defaultApi2")
        public Docket defaultApi2() {
            ApiSelectorBuilder builder = new Docket(DocumentationType.SWAGGER_2)
                    .enableUrlTemplating(false)
                    .apiInfo(apiInfo())
                    // 選擇那些路徑和api會(huì)生成document
                    .select()
                    // 對(duì)所有api進(jìn)行監(jiān)控
                    .apis(RequestHandlerSelectors.any())
                    //這里可以自定義過(guò)濾
                    .paths(this::filterPath);
    
            return builder.build();
        }
    
        private boolean filterPath(String path) {
            boolean ret = path.endsWith("/error");
            if (ret) {
                return false;
            }
            //這塊可以寫(xiě)其他的過(guò)濾邏輯
            return true;
        }
    
        private ApiInfo apiInfo() {
            return new ApiInfoBuilder()
                    .title("title")
                    .description("description")
                    .termsOfServiceUrl("https://www.baidu.com")
                    .version("1.0")
                    .contact(new Contact("nitric oxide", "www.baidu.com", "123@qq.com"))
                    .build();
        }
    }
    
  1. 使用swagger注解標(biāo)記接口
image
image
  1. 最后訪(fǎng)問(wèn)http://ip:port/doc.html來(lái)看接口的效果

    image

最后寫(xiě)一些swagger注解(不過(guò)我覺(jué)得上面的三個(gè)例子已經(jīng)覆蓋了大多數(shù)場(chǎng)景了)

作用范圍 API 使用位置
協(xié)議集描述 @Api controller類(lèi)上虚青,將一個(gè)class標(biāo)注為一個(gè)Swagger資源
協(xié)議描述 @ApiOperation controller方法上
非對(duì)象參數(shù)集 @ApiImplicitParams controller方法上
非對(duì)象參數(shù)描述 @ApiImplicitParam 用在@ApiImplicitParams的方法里邊
對(duì)象參數(shù)描述 @ApiParam 用在@ApiImplicitParams的方法里邊它呀,定義接收的參數(shù)形式
描述返回對(duì)象的意義 @ApiModel 用在返回對(duì)象類(lèi)上
對(duì)象屬性 @ApiModelProperty 用在參數(shù)對(duì)象的字段上
Response集 @ApiResponses 用在controller的方法上
Response @ApiResponse 用在 @ApiResponses里邊

詳細(xì)的介紹可以看這個(gè)鏈接

https://servicecomb.apache.org/references/java-chassis/zh_CN/build-provider/swagger-annotation.html

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市棒厘,隨后出現(xiàn)的幾起案子纵穿,更是在濱河造成了極大的恐慌,老刑警劉巖奢人,帶你破解...
    沈念sama閱讀 212,718評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件谓媒,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡何乎,警方通過(guò)查閱死者的電腦和手機(jī)句惯,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,683評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén)土辩,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人宗弯,你說(shuō)我怎么就攤上這事脯燃。” “怎么了蒙保?”我有些...
    開(kāi)封第一講書(shū)人閱讀 158,207評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵辕棚,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我邓厕,道長(zhǎng)逝嚎,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,755評(píng)論 1 284
  • 正文 為了忘掉前任详恼,我火速辦了婚禮补君,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘昧互。我一直安慰自己挽铁,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,862評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布敞掘。 她就那樣靜靜地躺著叽掘,像睡著了一般。 火紅的嫁衣襯著肌膚如雪玖雁。 梳的紋絲不亂的頭發(fā)上更扁,一...
    開(kāi)封第一講書(shū)人閱讀 50,050評(píng)論 1 291
  • 那天,我揣著相機(jī)與錄音赫冬,去河邊找鬼浓镜。 笑死,一個(gè)胖子當(dāng)著我的面吹牛劲厌,可吹牛的內(nèi)容都是我干的膛薛。 我是一名探鬼主播,決...
    沈念sama閱讀 39,136評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼补鼻,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼哄啄!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起辽幌,我...
    開(kāi)封第一講書(shū)人閱讀 37,882評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤增淹,失蹤者是張志新(化名)和其女友劉穎椿访,沒(méi)想到半個(gè)月后乌企,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,330評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡成玫,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,651評(píng)論 2 327
  • 正文 我和宋清朗相戀三年加酵,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了拳喻。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,789評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡猪腕,死狀恐怖冗澈,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情陋葡,我是刑警寧澤亚亲,帶...
    沈念sama閱讀 34,477評(píng)論 4 333
  • 正文 年R本政府宣布,位于F島的核電站腐缤,受9級(jí)特大地震影響捌归,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜岭粤,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,135評(píng)論 3 317
  • 文/蒙蒙 一惜索、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧剃浇,春花似錦巾兆、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,864評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至溜宽,卻和暖如春吉拳,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背适揉。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,099評(píng)論 1 267
  • 我被黑心中介騙來(lái)泰國(guó)打工留攒, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人嫉嘀。 一個(gè)月前我還...
    沈念sama閱讀 46,598評(píng)論 2 362
  • 正文 我出身青樓炼邀,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親剪侮。 傳聞我的和親對(duì)象是個(gè)殘疾皇子拭宁,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,697評(píng)論 2 351

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