欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringBoot整合Swagger2實(shí)例方法

 更新時(shí)間:2019年06月20日 14:32:58   投稿:laozhang  
在本篇文章里小編給大家整合了關(guān)于SpringBoot整合Swagger2的相關(guān)知識點(diǎn)內(nèi)容,有興趣的朋友們學(xué)習(xí)下。

在進(jìn)行軟件開發(fā)的時(shí)候免不了要寫接口文檔,這些文檔需要明確寫出接口的類型、請求的URL、傳參和返回值格式等信息,用于和前端交互或者提供給測試進(jìn)行接口測試。但是手寫文檔一方面帶給我們很大的工作量,另一方面如果接口有變更則需要頻繁修改并且發(fā)給相關(guān)的人,無形中增加了工作量。小編為大家介紹一個(gè)生成文檔的工具Swagger,上手簡單,學(xué)習(xí)成本低,非常適合開發(fā)SpringBoot項(xiàng)目,現(xiàn)在就跟著小編一起學(xué)習(xí)吧。

首先需要在pom文件中加入swagger2的依賴,依賴的jar包如下圖所示。

<dependency>
 <groupId>io.springfox</groupId>
 <artifactId>springfox-swagger2</artifactId>
 <version>2.8.0</version>
</dependency>
<dependency>
 <groupId>io.springfox</groupId>
 <artifactId>springfox-swagger-ui</artifactId>
 <version>2.8.0</version>
</dependency>

編寫Swagger配置類Swagger2Config,在類上增加@Configuration和@EnableSwagger2注解,表明這是一個(gè)配置類,同時(shí)開啟Swagger。如下的信息可以根據(jù)具體情況修改。

@Bean
public Docket api() {
  return new Docket(DocumentationType.SWAGGER_2)
      .apiInfo(apiInfo())
      .select()
      // 自行修改為自己的包路徑
      .apis(RequestHandlerSelectors.basePackage("com.spring.jpa.user"))
      .paths(PathSelectors.any())
      .build();
}

private ApiInfo apiInfo() {
  return new ApiInfoBuilder()
      .title("swagger-api文檔")
      .description("用戶信息相關(guān)")
      //服務(wù)條款網(wǎng)址
      .termsOfServiceUrl("https://baidu.com")
      .version("1.0")
      .contact(new Contact("NWSL", "http://baidu.com", "111111@qq.com"))
      .build();
}

 

接下來我們需要在Controller層添加注解,@Api(value="/test1", tags="測試用戶接口模塊"), @Api這個(gè)注解是用在請求的類上,表示對類的說明,其中tags="說明該類的作用,可以在UI界面上看到的注解",value="該參數(shù)沒什么意義,在UI界面上也看到,所以不需要配置"。該注解的使用如下圖所示。

 

接下來我們需要在方法上添加注解了,如下所示,@ApiOperation、@ApiImplicitParams、@ApiImplicitParam的作用如下圖所示。@ApiResponses:用在請求的方法上,表示一組響@ApiResponse:用在@ApiResponses中,一般用于表達(dá)一個(gè)錯(cuò)誤的響應(yīng)信息。

在方法中的使用如下圖所示。

@ApiOperation(value="添加用戶信息", notes = "添加用戶信息")
@ApiImplicitParams({
    @ApiImplicitParam(name = "name", value = "用戶姓名", required = true, dataType = "String",paramType = "query"),
    @ApiImplicitParam(name = "age", value = "用戶年齡", required = true,paramType = "query")
})

注意如果是Integer類型,那dataType = "Integer"就可以省略了,寫上了反而在生成的文檔調(diào)用的時(shí)候出錯(cuò)。

接下來我們介紹傳實(shí)體類參數(shù)的注解怎么寫,要使用到@ApiModel、@ApiModelProperty,具體的用法如下圖所示。在接收參數(shù)的實(shí)體類上我們需要添加這兩個(gè)注解,如下圖所示。

接口上注解寫完之后,我們啟動(dòng)服務(wù),然后打開swagger的UI頁面,注意8091端口是我本機(jī)服務(wù)啟動(dòng)的端口,請求的地址如下圖所示。我們可以看到每個(gè)Controller類都生成了文檔,UserController我們增加了類的注釋。

接下來我們測試UserController中的接口,如下圖所示,生成了UserController所有的接口文檔,我們首先來看添加用戶接口,如下圖所示,為什么Integer類型的age字段,在生成的接口文檔中參數(shù)類型變成了ref呢?上文提到過的,在寫注解的時(shí)候,dataType = "Integer"要省略掉,不然會出現(xiàn)這個(gè)問題。正確的如下所示,可以看到age為Integer類型了。

我們可以看到在接口的右側(cè)有Try it out,點(diǎn)擊該按鈕進(jìn)入到調(diào)用頁面。在如下的頁面填寫完參數(shù)之后執(zhí)行Execute即可,還是age參數(shù)ref的問題,此時(shí)執(zhí)行會提示錯(cuò)誤,要把注釋中的Integer類型去掉,在執(zhí)行即可。

接下來我們看一個(gè)Get請求,這個(gè)請求不需要傳參,直接執(zhí)行即可,結(jié)果如下圖所示。我們可以看到Swagger生成的restful形式的接口文檔,非常方便調(diào)試。

接下來我們執(zhí)行update的接口,這是上面我們用實(shí)體類接收參數(shù)的方法,可以看到參數(shù)的例子,我們修改完參數(shù)值后執(zhí)行即可。以上swagger2與springboot就集成完了。

相關(guān)文章

  • SpringCloud中的灰度路由使用詳解

    SpringCloud中的灰度路由使用詳解

    這篇文章主要介紹了SpringCloud中的灰度路由使用詳解,在微服務(wù)中,?通常為了高可用,?同一個(gè)服務(wù)往往采用集群方式部署,?即同時(shí)存在幾個(gè)相同的服務(wù),而灰度的核心就?是路由,?通過我們特定的策略去調(diào)用目標(biāo)服務(wù)線路,需要的朋友可以參考下
    2023-08-08
  • 使用Spring Security控制會話的方法

    使用Spring Security控制會話的方法

    在本文中,我們將說明Spring Security如何允許我們控制HTTP會話。這篇文章主要介紹了使用Spring Security控制會話 ,需要的朋友可以參考下
    2019-05-05
  • Java AQS的實(shí)現(xiàn)原理詳解

    Java AQS的實(shí)現(xiàn)原理詳解

    這篇文章主要借助了ReentrantLock來帶大家搞清楚AQS的實(shí)現(xiàn)原理,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,感興趣的小伙伴可以了解一下
    2023-04-04
  • 總結(jié)Junit4,Junit5,Jupiter之間的聯(lián)系

    總結(jié)Junit4,Junit5,Jupiter之間的聯(lián)系

    Jupiter和Junit5之間有什么聯(lián)系?Jupiter提供了哪些新的測試方法?如何用IDEA和Jupiter生成可讀性更好的測試報(bào)告?文中有非常詳細(xì)的說明,需要的朋友可以參考下
    2021-06-06
  • Java無法輸出中文問題及解決

    Java無法輸出中文問題及解決

    這篇文章主要介紹了Java無法輸出中文問題及解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • 使用Springboot 打jar包實(shí)現(xiàn)分離依賴lib和配置

    使用Springboot 打jar包實(shí)現(xiàn)分離依賴lib和配置

    這篇文章主要介紹了使用Springboot 打jar包實(shí)現(xiàn)分離依賴lib和配置方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-02-02
  • SpringMVC找不到Controller路徑的解決方案

    SpringMVC找不到Controller路徑的解決方案

    這篇文章主要介紹了SpringMVC找不到Controller路徑的解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • Java飛行記錄器JFR功能實(shí)現(xiàn)過程圖解

    Java飛行記錄器JFR功能實(shí)現(xiàn)過程圖解

    這篇文章主要介紹了Java飛行記錄器JFR功能實(shí)現(xiàn)過程圖解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-05-05
  • Java實(shí)現(xiàn)JDK動(dòng)態(tài)代理的原理詳解

    Java實(shí)現(xiàn)JDK動(dòng)態(tài)代理的原理詳解

    這篇文章主要介紹了Java實(shí)現(xiàn)JDK動(dòng)態(tài)代理的原理詳解,Java常用的動(dòng)態(tài)代理模式有JDK動(dòng)態(tài)代理,也有cglib動(dòng)態(tài)代理,本文重點(diǎn)講解JDK的動(dòng)態(tài)代理,需要的小伙伴可以參考一下的相關(guān)資料
    2022-07-07
  • Java thread.isInterrupted() 返回值不確定結(jié)果分析解決

    Java thread.isInterrupted() 返回值不確定結(jié)果分析解決

    這篇文章主要介紹了Java thread.isInterrupted() 返回值不確定結(jié)果分析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-12-12

最新評論