溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

SpringBoot中使用怎么Swagger

發(fā)布時(shí)間:2022-04-02 16:31:20 來(lái)源:億速云 閱讀:192 作者:iii 欄目:大數(shù)據(jù)

本篇內(nèi)容主要講解“SpringBoot中使用怎么Swagger”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“SpringBoot中使用怎么Swagger”吧!

整合Swagger

依賴(lài):

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

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

配置詳解

詳細(xì)配置:

spring:
  swagger:
    enabled: true
    title: 標(biāo)題
    description: 描述信息
    version: 系統(tǒng)版本號(hào)
    contact:
      name: 維護(hù)者信息
    base-package: swagger掃描的基礎(chǔ)包,默認(rèn):全掃描(分組情況下此處可不配置)
    #全局參數(shù),比如Token之類(lèi)的驗(yàn)證信息可以全局話(huà)配置
    global-operation-parameters:
    -   description: "Token信息,必填項(xiàng)"
        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: 星空小屋 - 文章微服務(wù)接口
    description: 文章微服務(wù)相關(guān)接口,包括文章、模塊、知識(shí)點(diǎn)管理等
    version: 1.0.0 - SNAPSHOT
    contact:
      name: cv大魔王
      email: 1919301983@qq.com
    host: localhost
    enabled: true
    security:
      filter-plugin: true # 配置賬號(hào)密碼
      username: root
      password: root

配置攔截器,后面有攔截器配置,如果有讀者需要在自己的項(xiàng)目使用,請(qǐng)?jiān)械臄r截器配置中修改,忽略掉以下路徑,以免被攔截導(dǎo)致無(wú)法訪(fǎng)問(wèn)?!皊wagger-ui.html”, “static/css/", "static/js/”, “swagger-resources”, “/**/error”, “v2/api-docs”

測(cè)試使用

運(yùn)行項(xiàng)目,訪(fǎng)問(wèn)IP+端口號(hào)/swagger-ui.html,例如在瀏覽器訪(fǎng)問(wèn):http://127.0.0.1:13001/swagger-ui.html

SpringBoot中使用怎么Swagger

登錄后的效果:

SpringBoot中使用怎么Swagger

復(fù)習(xí)――常用注解

對(duì)swagger熟悉的小伙伴的請(qǐng)忽略“常用注解段落”

`@Api`:用在 Controller 類(lèi)上,描述該類(lèi)的作用
  1. `value`="描述信息"
  2. `description`="詳細(xì)描述該類(lèi)的作用"

@ApiOperation:用在 Controller 請(qǐng)求方法上,描述方法的作用。

@ApiModel:用在請(qǐng)求參數(shù)是對(duì)象上,描述該對(duì)象類(lèi)的作用

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

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

  • value:屬性的描述

  • hidden:是否是查詢(xún)條件屬性, false:(默認(rèn)值)在api文檔顯示,作為查詢(xún)條件;true 隱藏,不是條件屬性

// 請(qǐng)求方法參數(shù)是 CategoryREQ 對(duì)象
public Result search(@RequestBody CategoryREQ req) {}

@ApiModel(value="CategoryREQ對(duì)象", description="類(lèi)別查詢(xún)條件")
public class CategoryREQ extends BaseRequest<Category> {
    
    @ApiModelProperty(value = "分類(lèi)名稱(chēng)")
    private String name;

    @ApiModelProperty(value="狀態(tài)(1:正常,0:禁用)")
    private Integer status;
}
  • @ApiResponses:用在請(qǐng)求的方法上,用于表示一組響應(yīng)

  • @ApiResponse:用在 @ApiResponses 中,一般用于表達(dá)一個(gè)錯(cuò)誤的響應(yīng)信息,注解參數(shù):

  • code:數(shù)字,如 400message:信息,如 “參數(shù)填寫(xiě)錯(cuò)誤”response:拋出異常的類(lèi)

@ApiIgnore: 使用該注解忽略這個(gè) API

@ApiImplicitParams:用在請(qǐng)求方法上,對(duì)多個(gè)請(qǐng)求參數(shù)增加描述

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

  1. name:參數(shù)名

  2. value:描述參數(shù)的作用

  3. dataType:參數(shù)類(lèi)型,參數(shù)類(lèi)型,默認(rèn)String,其它值 dataType=“Integer”

  4. defaultValue:參數(shù)默認(rèn)值

  5. required:參數(shù)是否必傳(true/false)

  6. paramTpye:指定參數(shù)放在哪些地方(header/query/path/body/form)

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

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

到此,相信大家對(duì)“SpringBoot中使用怎么Swagger”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢(xún),關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI