一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Java SpringBoot詳解集成以及配置Swagger流程

Java SpringBoot詳解集成以及配置Swagger流程

2022-03-02 00:45龍弟-idea Java教程

Swagger 是一個規范和完整的框架,用于生成、描述、調用和可視化 RESTful 風格的 Web 服務。總體目標是使客戶端和文件系統作為服務器以同樣的速度來更新。文件的方法,參數和模型緊密集成到服務器端的代碼,允許API來始終保持同

一、swagge簡介

前后端分離:

后端U后端控制層,服務層,數據訪問層【后端團隊】

前端:前端控制層,視圖層【前端團隊】

前后端通過API進行交互

前后端相對獨立且松耦合

產生問題:前后端集成,前端或者后端無法做到“及時協商,盡早解決”,最終導致問題集中爆發

解決方法:首先定義schema [ 計劃的提綱 ],并實時跟蹤最新的API,降低集成風險

前后端分離: 前端測試后端接口:postman
后端提供接口,需要實時更新最新的消息及改動!

Swagger

  • 號稱世界上最流行的API框架
  • Restful Api 文檔在線自動生成器 => API 文檔 與API 定義同步更新
  • 直接運行,在線測試API
  • 支持多種語言 (如:Java,PHP等)
  • 官網:API Documentation & Design Tools for Teams | Swagger

Java SpringBoot詳解集成以及配置Swagger流程

 

二、SpringBoot集成Swagger

1、新建一個SpringBoot-web項目

2、添加Maven依賴

<!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger2 -->
<dependency>
 <groupId>io.springfox</groupId>
 <artifactId>springfox-swagger2</artifactId>
 <version>2.9.2</version>
</dependency>
<!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger-ui -->
<dependency>
 <groupId>io.springfox</groupId>
 <artifactId>springfox-swagger-ui</artifactId>
 <version>2.9.2</version>
</dependency>

3、編寫HelloController,測試確保運行成功!

Java SpringBoot詳解集成以及配置Swagger流程

4、要使用Swagger,我們需要編寫一個配置類-SwaggerConfig來配置 Swagger

@Configuration
@EnableSwagger2        //開啟Swagger2
public class SwaggerConfig {
  
}

5.訪問測試 :http://localhost:8081/swagger-ui.html,可以看到swagger的界面;

Java SpringBoot詳解集成以及配置Swagger流程

 

三、配置Swagger

1、Swagger實例Bean是Docket,所以通過配置Docket實例來配置Swaggger。

//配置了Swagger的Docket的bean實例
  @Bean
  public Docket docket(){
      return new Docket(DocumentationType.SWAGGER_2);

  }

2、可以通過apiInfo()屬性配置文檔信息

  //配置文檔信息
  private ApiInfo apiInfo() {
      Contact contact = new Contact("弟", "https://blog.csdn.net/weixin_48838340", "聯系人郵箱");
      return new ApiInfo(
              "弟的Swagger學習文檔", // 標題
              "學習演示如何配置Swagger", // 描述
              "v1.0", // 版本
              "https://blog.csdn.net/weixin_48838340", // 組織鏈接
              contact, // 聯系人信息
              "Apach 2.0 許可", // 許可
              "許可鏈接", // 許可連接
              new ArrayList<>()// 擴展
      );
  }
}

3、Docket 實例關聯上 apiInfo()

  @Bean
  public Docket docket(){
      return new Docket(DocumentationType.SWAGGER_2).apiInfo(apiInfo());
  }

4.重啟項目

Java SpringBoot詳解集成以及配置Swagger流程

 

四、配置掃描接口

構建Docket時通過select()方法配置怎么掃描接口。

  //配置了Swagger的Docket的bean實例
  @Bean
  public Docket docket(){
      return new Docket(DocumentationType.SWAGGER_2)
              .apiInfo(apiInfo())
              .select()// 通過.select()方法,去配置掃描接口,RequestHandlerSelectors配置如何掃描接口
                //any() // 掃描所有,項目中的所有接口都會被掃描到
               // none() // 不掃描接口
      // withMethodAnnotation通過方法上的注解掃描,如withMethodAnnotation(GetMapping.class)只掃描get請求
      // 通過類上的注解掃描,如.withClassAnnotation(Controller.class)只掃描有controller注解的類中的接口
              .apis(RequestHandlerSelectors.basePackage("com.longdi.swagger.controller"))
              //path()  過濾什么路徑
              .paths(PathSelectors.ant("/longdi/**"))
              .build();
  };

 

五、配置Swagger開關

1、通過enable()方法配置是否啟用swagger

  @Bean
  public Docket docket() {
      return new Docket(DocumentationType.SWAGGER_2)
              .apiInfo(apiInfo())
              .enable(false) //配置是否啟用Swagger,如果是false,在瀏覽器將無法訪問
              .select()// 通過.select()方法,去配置掃描接口,RequestHandlerSelectors配置如何掃描接口
              .apis(RequestHandlerSelectors.basePackage("com.longdi.swagger.controller"))
              // 配置如何通過path過濾,即這里只掃描請求以/longdi開頭的接口
              .paths(PathSelectors.ant("/longdi/**"))
              .build();
  }

2.如何動態配置當項目處于test、dev環境時顯示swagger

  @Bean
  public Docket docket(Environment environment) {
      // 設置要顯示swagger的環境
      Profiles of = Profiles.of("dev", "test");
      // 判斷當前是否處于該環境
      // 通過 enable() 接收此參數判斷是否要顯示
      boolean b = environment.acceptsProfiles(of);

      return new Docket(DocumentationType.SWAGGER_2)
              .apiInfo(apiInfo())
              .enable(b) //配置是否啟用Swagger,如果是false,在瀏覽器將無法訪問
              .select()// 通過.select()方法,去配置掃描接口,RequestHandlerSelectors配置如何掃描接口
              .apis(RequestHandlerSelectors.basePackage("com.longdi.swagger.controller"))
              // 配置如何通過path過濾,即這里只掃描請求以/longdi開頭的接口
              .paths(PathSelectors.ant("/longdi/**"))
              .build();
  }

 

六、配置API分組

1.如果沒有配置分組,默認是default。通過groupName()方法即可配置分組:

  @Bean
  public Docket docket1(Environment environment) {
      return new Docket(DocumentationType.SWAGGER_2).apiInfo(apiInfo())
              .groupName("A") ;// 配置分組
      // 省略配置....
  }

2.配置多個分組只需要配置多個docket即可

Java SpringBoot詳解集成以及配置Swagger流程

3.重啟看到下面效果

Java SpringBoot詳解集成以及配置Swagger流程

 

七、實體配置

1.新建一個實體類

@ApiModel為類添加注釋

@ApiModelProperty為類屬性添加注釋

Java SpringBoot詳解集成以及配置Swagger流程

2.只要這個實體在請求接口的返回值上(即使是泛型),都能映射到實體項中:

  //只要我們的接口中,返回值中存在實體類,它就會被掃描到Swagger中
  @PostMapping(value="/user")
  public User getUser(){
      return new User();
  }

3.查看效果

Java SpringBoot詳解集成以及配置Swagger流程

4.可以給請求的接口配置一些注釋

  //Operation接口,不是放在類上的,是方法
  @ApiOperation("弟的接口")
  @GetMapping("/hello2")
  public String kuang(@ApiParam("這個名字會被返回")String username){
      return "hello"+username;
  }

Java SpringBoot詳解集成以及配置Swagger流程

 

八、總結:

1.我們可以通過Swagger給一些比較難理解的屬性或者接口,增加注釋信息

2接口文檔實時更新
3.可以在線測試

Swagger是一個優秀的工具,幾乎所有大公司都有使用它

【注意點】在正式發布的時候,需要關閉Swagger! 因為出于安全考慮,同時節省運行的內存!

到此這篇關于Java SpringBoot詳解集成以及配置Swagger流程的文章就介紹到這了,更多相關Java SpringBoot Swagger內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://blog.csdn.net/weixin_48838340/article/details/120706190

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久er99热精品一区二区 | 女医学护士一级毛片 | 色偷偷亚洲综合网亚洲 | 国产精品久久久久不卡绿巨人 | 人人干国产 | 国产成人久视频免费 | 97社区| 九九成人免费视频 | 香蕉久久一区二区三区啪啪 | 国产有码在线 | 国产成人精品免费视频大全五级 | b片在线观看 | 风间由美在线播放 | 欧美午夜性春猛交bbb | 99精品国产成人一区二区在线 | 亚洲 欧美 偷自乱 图片 | 大片毛片女女女女女女女 | 日韩在线视频一区二区三区 | 国产综合成人久久大片91 | 青草视频在线观看免费网站 | 男女全黄h全肉细节文 | 精品久久亚洲 | 成人免费播放器 | 波多野结衣52部合集在线观看 | 热99这里有精品综合久久 | 国产精品视频一区二区三区不卡 | 亚洲精品日韩专区在线观看 | 亚洲午夜精品久久久久久成年 | 久草高清在线 | 青青青青青 | 好湿好紧好大野战 | 色综合91久久精品中文字幕 | 国产一区二区在线观看美女 | 日韩亚洲国产欧美精品 | www.毛片在线观看 | 久久九九精品国产自在现线拍 | 成人免费毛片一区二区三区 | 人妖巨茎video | 美女把小内内脱个精光打屁屁 | 九九精品热 | 久久精品国产视频澳门 |