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

詳解spring cloud整合Swagger2構建RESTful服務的APIs

 更新時間:2018年01月25日 11:13:34   作者:牛奮lch  
這篇文章主要介紹了詳解spring cloud整合Swagger2構建RESTful服務的APIs,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

前言

在前面的博客中,我們將服務注冊到了Eureka上,可以從Eureka的UI界面中,看到有哪些服務已經注冊到了Eureka Server上,但是,如果我們想查看當前服務提供了哪些RESTful接口方法的話,就無從獲取了,傳統(tǒng)的方法是梳理一篇服務的接口文檔來供開發(fā)人員之間來進行交流,這種情況下,很多時候,會造成文檔和代碼的不一致性,比如說代碼改了,但是接口文檔沒有改等問題,而Swagger2則給我們提供了一套完美的解決方案,下面,我們來看看Swagger2是如何來解決問題的。

一、引入Swagger2依賴的jar包

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

二、初始化Swagger2的配置

@Configuration 
@EnableSwagger2 // 啟用Swagger2 
public class Swagger2 { 
 
  @Bean 
  public Docket createRestApi() {// 創(chuàng)建API基本信息 
    return new Docket(DocumentationType.SWAGGER_2) 
        .apiInfo(apiInfo()) 
        .select() 
        .apis(RequestHandlerSelectors.basePackage("com.chhliu.jpa"))// 掃描該包下的所有需要在Swagger中展示的API,@ApiIgnore注解標注的除外 
        .paths(PathSelectors.any()) 
        .build(); 
  } 
 
  private ApiInfo apiInfo() {// 創(chuàng)建API的基本信息,這些信息會在Swagger UI中進行顯示 
    return new ApiInfoBuilder() 
        .title("Spring Boot中使用Swagger2構建RESTful APIs")// API 標題 
        .description("rdcloud-jpa提供的RESTful APIs")// API描述 
        .contact("chhliu@")// 聯(lián)系人 
        .version("1.0")// 版本號 
        .build(); 
  } 
 
} 

注:該配置類需要在Application同級目錄下創(chuàng)建,在項目啟動的時候,就初始化該配置類

三、完善API文檔信息

public interface SonarControllerI { 
  @ApiOperation(value="獲取項目組Sonar對應的Url信息", notes="根據(jù)id獲取項目組Sonar對應的Url信息")// 使用該注解描述接口方法信息 
  @ApiImplicitParams({ 
      @ApiImplicitParam(name = "id", value = "SonarUrl表ID", required = true, dataType = "Long", paramType="path") 
  })// 使用該注解描述方法參數(shù)信息,此處需要注意的是paramType參數(shù),需要配置成path,否則在UI中訪問接口方法時,會報錯 
  @GetMapping("/get/{id}") 
  SonarUrl get(@PathVariable Long id); 
   
  @ApiOperation(value="獲取項目組Sonar對應的所有Url信息") 
  @GetMapping("/get/all") 
  List<SonarUrl> getAll(); 
} 

注:paramType表示參數(shù)的類型,可選的值為"path","body","query","header","form"

四、完善返回類型信息

@Entity(name = "SONAR_URL") 
public class SonarUrl implements Serializable { 
 
  /** 
   * 
   */ 
  private static final long serialVersionUID = 1L; 
  @ApiModelProperty(value="主鍵", hidden=false, notes="主鍵,隱藏", required=true, dataType="Long")// 使用該注解描述屬性信息,當hidden=true時,該屬性不會在api中顯示 
  @Id 
  @GeneratedValue(strategy = GenerationType.AUTO) 
  private Long id; 
   
  @ApiModelProperty(value="URL鏈接地址") 
  @Column(name="URL") 
  private String url; 
   
  @ApiModelProperty(value="項目組") 
  @Column(name="TEAM") 
  private String team; 
 
  @ApiModelProperty(value="部門") 
  @Column(name="DEPARTMENT") 
  private String department; 
    ……省略getter,setter方法…… 
 } 

五、啟動應用

1、在瀏覽器中輸入:http://localhost:7622/swagger-ui.html

2、結果如下:

六、API文檔訪問與測試

Swagger除了提供API接口查看的功能外,還提供了調試測試功能


測試結果如下:


以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • java類加載器和類反射使用示例

    java類加載器和類反射使用示例

    這篇文章主要介紹了java類加載器和類反射使用示例,需要的朋友可以參考下
    2014-03-03
  • springboot使用dubbo和zookeeper代碼實例

    springboot使用dubbo和zookeeper代碼實例

    這篇文章主要介紹了springboot使用dubbo和zookeeper代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-11-11
  • spring boot 集成 shiro 自定義密碼驗證 自定義freemarker標簽根據(jù)權限渲染不同頁面(推薦

    spring boot 集成 shiro 自定義密碼驗證 自定義freemarker標簽根據(jù)權限渲染不同頁面(推薦

    這篇文章主要介紹了spring-boot 集成 shiro 自定義密碼驗證 自定義freemarker標簽根據(jù)權限渲染不同頁面,需要的朋友可以參考下
    2018-12-12
  • Java異常處理try?catch的基本用法

    Java異常處理try?catch的基本用法

    try就像一個網,把try{}里面的代碼所拋出的異常都網住,然后把異常交給catch{}里面的代碼去處理。最后執(zhí)行finally之中的代碼。無論try中代碼有沒有異常,也無論catch是否將異常捕獲到,finally中的代碼都一定會被執(zhí)行。
    2021-12-12
  • SpringBoot解決跨域問題小結

    SpringBoot解決跨域問題小結

    在現(xiàn)代Web應用中,由于安全性和隱私的考慮,瀏覽器限制了從一個域向另一個域發(fā)起的跨域HTTP請求,Spring?Boot提供了多種方式來處理跨域請求,本文將介紹其中的幾種方法,感興趣的朋友一起看看吧
    2023-12-12
  • 關于解決雪花算法生成的ID傳輸前端后精度丟失問題

    關于解決雪花算法生成的ID傳輸前端后精度丟失問題

    這篇文章主要介紹了關于解決雪花算法生成的ID傳輸前端后精度丟失問題,雪花算法生成的ID傳輸?shù)角岸藭r,會出現(xiàn)后三位精度丟失,本文提供了解決思路,需要的朋友可以參考下
    2023-03-03
  • Java后臺實現(xiàn)微信支付和微信退款

    Java后臺實現(xiàn)微信支付和微信退款

    這篇文章主要介紹了Java后臺實現(xiàn)微信支付和微信退款,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-03-03
  • Java使用FileInputStream流讀取文件示例詳解

    Java使用FileInputStream流讀取文件示例詳解

    這篇文章主要介紹了Java使用FileInputStream流讀取文件示例詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-07-07
  • Java Date類常用示例_動力節(jié)點Java學院整理

    Java Date類常用示例_動力節(jié)點Java學院整理

    在JDK1.0中,Date類是唯一的一個代表時間的類,但是由于Date類不便于實現(xiàn)國際化,所以從JDK1.1版本開始,推薦使用Calendar類進行時間和日期處理。這里簡單介紹一下Date類的使用,需要的朋友可以參考下
    2017-05-05
  • java簡單坦克大戰(zhàn)制作代碼

    java簡單坦克大戰(zhàn)制作代碼

    這篇文章主要介紹了java簡單坦克大戰(zhàn)制作代碼,利用Java語言中的集合、Swing、線程等知識點編寫一個坦克大戰(zhàn)游戲,需要的朋友可以參考下
    2016-07-07

最新評論