溫馨提示×

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

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

在SpringBoot環(huán)境如何實(shí)現(xiàn)整合Swagger2

發(fā)布時(shí)間:2020-11-07 16:03:25 來源:億速云 閱讀:134 作者:Leah 欄目:開發(fā)技術(shù)

本篇文章給大家分享的是有關(guān)在SpringBoot環(huán)境如何實(shí)現(xiàn)整合Swagger2,小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

一、導(dǎo)入maven包 

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

二、添加工具類

@Configuration
@EnableSwagger2
public class SwaggerConfig {
  @Bean
  public Docket createRestApi() {
    return new Docket(DocumentationType.SWAGGER_2)
        .pathMapping("/")
        .select()
        .apis(RequestHandlerSelectors.basePackage("com.nvn.controller"))
        .paths(PathSelectors.any())
        .build().apiInfo(new ApiInfoBuilder()
            .title("SpringBoot整合Swagger")
            .description("SpringBoot整合Swagger,詳細(xì)信息......")
            .version("1.0")
            .build());
  }
}

三、添加注解

@RestController
@Api(tags = "用戶管理相關(guān)接口")
@RequestMapping("/user")
public class UserController {

  @PostMapping("/")
  @ApiOperation("添加用戶的接口")
  @ApiImplicitParams({
      @ApiImplicitParam(name = "username", value = "用戶名", defaultValue = "李四"),
      @ApiImplicitParam(name = "address", value = "用戶地址", defaultValue = "深圳", required = true)
  }
  )
  public RespBean addUser(String username, @RequestParam(required = true) String address) {
    return new RespBean();
  }

  @GetMapping("/")
  @ApiOperation("根據(jù)id查詢用戶的接口")
  @ApiImplicitParam(name = "id", value = "用戶id", defaultValue = "99", required = true)
  public User getUserById(@PathVariable Integer id) {
    User user = new User();
    user.setId(id);
    return user;
  }
  @PutMapping("/{id}")
  @ApiOperation("根據(jù)id更新用戶的接口")
  public User updateUserById(@RequestBody User user) {
    return user;
  }
}

四、注解說明

  • @Api注解可以用來標(biāo)記當(dāng)前Controller的功能。
  • @ApiOperation注解用來標(biāo)記一個(gè)方法的作用。
  • @ApiImplicitParam注解用來描述一個(gè)參數(shù),可以配置參數(shù)的中文含義,也可以給參數(shù)設(shè)置默認(rèn)值,這樣在接口測(cè)試的時(shí)候可以避免手動(dòng)輸入。
  • 如果有多個(gè)參數(shù),則需要使用多個(gè)@ApiImplicitParam注解來描述,多個(gè)@ApiImplicitParam注解需要放在一個(gè)@ApiImplicitParams注解中。
  • @ApiImplicitParam注解中雖然可以指定參數(shù)是必填的,但是卻不能代替@RequestParam(required = true),前者的必填只是在Swagger2框架內(nèi)必填,拋棄了Swagger2,這個(gè)限制就沒用了,所以假如開發(fā)者需要指定一個(gè)參數(shù)必填,@RequestParam(required = true)注解還是不能省略。
     

五、如果參數(shù)是一個(gè)對(duì)象,對(duì)于參數(shù)的描述可以放在實(shí)體類中。

@ApiModel
public class User {
  @ApiModelProperty(value = "用戶id")
  private Integer id;
  @ApiModelProperty(value = "用戶名")
  private String username;
  @ApiModelProperty(value = "用戶地址")
  private String address;
  //getter/setter
}

六、效果

在SpringBoot環(huán)境如何實(shí)現(xiàn)整合Swagger2

附:如果我們的Spring Boot項(xiàng)目中集成了Spring Security,那么如果不做額外配置,Swagger2文檔可能會(huì)被攔截,此時(shí)只需要在Spring Security的配置類中重寫configure方法,添加如下過濾即可:

@Override
public void configure(WebSecurity web) throws Exception {
  web.ignoring()
      .antMatchers("/swagger-ui.html")
      .antMatchers("/v2/**")
      .antMatchers("/swagger-resources/**");
}

以上就是在SpringBoot環(huán)境如何實(shí)現(xiàn)整合Swagger2,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見到或用到的。希望你能通過這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

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

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

AI