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

SpringBoot中使用Swagger的超簡單方法

 更新時間:2021年07月19日 10:10:09   作者:CV大魔王  
大家一致認為springBoot使用swagger太麻煩了,每次都需要編寫config,今天小編告訴大家一種超簡單配置方法,教大家如何整合swagger,感興趣的朋友跟隨小編一起看看吧

Swagger號稱世界上最流行的Api框架,它是RestFul 風格的Api。文檔在線自動生成工具:Api文檔與API定義同步更新??梢灾苯舆\行,能在線測試API接口;支持多種編程語言:(Java、PHP等)。

官網(wǎng):https://swagger.io/

springBoot使用swagger太麻煩,每次都需要編寫config?如果我告訴你有這么一種方式,你只需要配置yml文件,你學還是不學?

整合Swagger

依賴:

<!-- Swagger -->
<dependency>
    <groupId>com.battcn</groupId>
    <artifactId>swagger-spring-boot-starter</artifactId>
    <version>2.1.5-RELEASE</version>
</dependency>

我這里的Swagger大家應該也發(fā)現(xiàn)了,并非是官方的,這個是第三方整合的,配置更加簡單。

配置詳解

詳細配置:

spring:
  swagger:
    enabled: true
    title: 標題
    description: 描述信息
    version: 系統(tǒng)版本號
    contact:
      name: 維護者信息
    base-package: swagger掃描的基礎包,默認:全掃描(分組情況下此處可不配置)
    #全局參數(shù),比如Token之類的驗證信息可以全局話配置
    global-operation-parameters:
    -   description: 'Token信息,必填項'
        modelRef: 'string'
        name: 'Authorization'
        parameter-type: 'header'
        required: true
    groups:
      basic-group:
        base-package: com.battcn.controller.basic
      system-group:
        base-package: com.battcn.controller.system

我的配置

spring:
  swagger:
    title: 星空小屋 - 文章微服務接口
    description: 文章微服務相關接口,包括文章、模塊、知識點管理等
    version: 1.0.0 - SNAPSHOT
    contact:
      name: cv大魔王
      email: 1919301983@qq.com
    host: localhost
    enabled: true
    security:
      filter-plugin: true # 配置賬號密碼
      username: root
      password: root

配置攔截器,后面有攔截器配置,如果有讀者需要在自己的項目使用,請原有的攔截器配置中修改,忽略掉以下路徑,以免被攔截導致無法訪問?!皊wagger-ui.html”, “static/css/", "static/js/”, “swagger-resources”, “/**/error”, “v2/api-docs”

測試使用

運行項目,訪問IP+端口號/swagger-ui.html,例如在瀏覽器訪問:http://127.0.0.1:13001/swagger-ui.html

image-20210221184645521

登錄后的效果:

image-20210221184734860

復習——常用注解

對swagger熟悉的小伙伴的請忽略“常用注解段落”

`@Api`:用在 Controller 類上,描述該類的作用
  1. `value`="描述信息"
  2. `description`="詳細描述該類的作用"

@ApiOperation:用在 Controller 請求方法上,描述方法的作用。

@ApiModel:用在請求參數(shù)是對象上,描述該對象類的作用

// 在對象類上使用@ApiModel
@ApiModel(value="CategoryREQ對象", description="類別查詢條件")
public class CategoryREQ extends BaseRequest<Category> {
}

@ApiModelProperty:用在請求參數(shù)是對象的屬性上,描述對象屬性的作用。

  • value:屬性的描述
  • hidden:是否是查詢條件屬性, false:(默認值)在api文檔顯示,作為查詢條件;true 隱藏,不是條件屬性
// 請求方法參數(shù)是 CategoryREQ 對象
public Result search(@RequestBody CategoryREQ req) {}

@ApiModel(value="CategoryREQ對象", description="類別查詢條件")
public class CategoryREQ extends BaseRequest<Category> {
    
    @ApiModelProperty(value = "分類名稱")
    private String name;

    @ApiModelProperty(value="狀態(tài)(1:正常,0:禁用)")
    private Integer status;
}
  • @ApiResponses:用在請求的方法上,用于表示一組響應
  • @ApiResponse:用在 @ApiResponses 中,一般用于表達一個錯誤的響應信息,注解參數(shù):
  • code:數(shù)字,如 400message:信息,如 “參數(shù)填寫錯誤”response:拋出異常的類

@ApiIgnore: 使用該注解忽略這個 API

@ApiImplicitParams:用在請求方法上,對多個請求參數(shù)增加描述

@ApiImplicitParam:可單獨使用,或在 @ApiImplicitParams 中使用,給方法的一個請求參數(shù)增加描述。

  1. name:參數(shù)名
  2. value:描述參數(shù)的作用
  3. dataType:參數(shù)類型,參數(shù)類型,默認String,其它值 dataType=“Integer”
  4. defaultValue:參數(shù)默認值
  5. required:參數(shù)是否必傳(true/false)
  6. paramTpye:指定參數(shù)放在哪些地方(header/query/path/body/form)

header :參數(shù)在request headers 里邊提交 @RequestHeader
query :直接跟參數(shù)完成自動映射賦值 @RequestParam
path :以路徑變量的形式提交數(shù)據(jù) @PathVariable
body :以流的形式提交 僅支持POST(不常用)
form :以form表單的形式提交 僅支持POST (不常用)
參考:

// 請求方法有多個請求參數(shù) size, current
@ApiImplicitParams({
    @ApiImplicitParam(name="current", value="頁碼", required=true, paramType="path",dataType="int"),
    @ApiImplicitParam(name="size", value="每頁記錄數(shù)", required=true, paramType="path",dataType="int")
})
@ApiOperation("根據(jù)分類名稱與狀態(tài)查詢分類列表接口")
@PostMapping("/search/{current}/{size}")
Result search(@RequestBody CategoryREQ req, @PathVariable int current, @PathVariable int size);

到此這篇關于SpringBoot中使用Swagger的超簡單方法的文章就介紹到這了,更多相關SpringBoot使用Swagger內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 詳解springboot項目帶Tomcat和不帶Tomcat的兩種打包方式

    詳解springboot項目帶Tomcat和不帶Tomcat的兩種打包方式

    這篇文章主要介紹了詳解springboot項目帶Tomcat和不帶Tomcat的兩種打包方式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-09-09
  • Spring Boot 2.0多數(shù)據(jù)源配置方法實例詳解

    Spring Boot 2.0多數(shù)據(jù)源配置方法實例詳解

    這篇文章主要介紹了Spring Boot 2.0多數(shù)據(jù)源配置方法實例詳解,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-09-09
  • Java中使用SQLite數(shù)據(jù)庫的實現(xiàn)示例

    Java中使用SQLite數(shù)據(jù)庫的實現(xiàn)示例

    SQLite是一種嵌入式數(shù)據(jù)庫引擎,可以在各種平臺上使用,本文主要介紹了Java中使用SQLite數(shù)據(jù)庫的實現(xiàn)示例,具有一定的參考價值,感興趣的可以了解一下
    2024-01-01
  • SpringBoot整合Swagger2的完整過程記錄

    SpringBoot整合Swagger2的完整過程記錄

    Swagger是一款RESTful接口的文檔在線自動生成、功能測試功能框架,這篇文章主要給大家介紹了關于SpringBoot整合Swagger2的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2021-09-09
  • Java內存之happens-before和重排序

    Java內存之happens-before和重排序

    在JMM(Java內存模型)中,如果一個操作執(zhí)行的結果需要對另一個操作可見,那么這兩個操作之間必須存在happens-before關系。下面小編來簡單介紹一下
    2019-05-05
  • IntellJ IDEA JAVA代碼任務標記實例解析

    IntellJ IDEA JAVA代碼任務標記實例解析

    這篇文章主要介紹了IntellJ IDEA JAVA代碼任務標記實例解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-07-07
  • springboot處理異常的5種方式

    springboot處理異常的5種方式

    本文主要介紹了springboot處理異常的5種方式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-08-08
  • Java中的for循環(huán)結構及實例

    Java中的for循環(huán)結構及實例

    這篇文章主要介紹了Java中的for循環(huán)結構及實例,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • java基于ConcurrentHashMap設計細粒度實現(xiàn)代碼

    java基于ConcurrentHashMap設計細粒度實現(xiàn)代碼

    這篇文章主要介紹了java基于ConcurrentHashMap設計細粒度實現(xiàn)代碼,通過ConcurrentHashMap實現(xiàn)細粒度,具有一定參考價值,需要的朋友可以了解。
    2017-10-10
  • 簡單實現(xiàn)Java web服務器

    簡單實現(xiàn)Java web服務器

    這篇文章主要為大家詳細介紹了簡單實現(xiàn)Java web服務器的詳細步驟,感興趣的小伙伴們可以參考一下
    2016-06-06

最新評論