关于springboot:Spring-boot-接入swagger以及使用

4次阅读

共计 4823 个字符,预计需要花费 13 分钟才能阅读完成。

Springboot 集成 Swagger 2(springfox)

1、集成

导入依赖

Springfox Swagger2:

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

Springfox Swagger UI:

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

配置 swagger

@Configuration
@EnableSwagger2
public class SwaggerConfig{}

创立一个以上一个类配置 swagger 即可。

默认成果

拜访界面:IP:port/swagger-ui.html

2、配置

在以上配置类中增加办法:

// 配置 swagger 的 Docket 的 Bean 实例
@Bean
public Docket docket(){return new Docket(DocumentationType.SWAGGER_2).apiInfo(this.apiInfo());
}

// 自定义 swagger 信息
private ApiInfo apiInfo(){Contact contact = new Contact("name","url","email");
    return new ApiInfo("title","description","version","termsOfServiceUrl",contact,"license",licenseUrl,new ArrayList());
}

3、配置扫描接口

我的项目中并不需要 swagger 将整个我的项目的所有类裸露进来,通过以上配置的 Bean 实例,设置 swagger 关注并显示的接口,以及是否开启应用:

return new Docket(DocumentationType.SWAGGER_2)
    .apiInfo(apiInfo())
    .enable(false)//false 时,浏览器不能拜访,默认为 true
    .select()
    //RequestHandlerSelect,配置要扫描接口的形式
    //basePackage("包门路"): 指定要扫描的包
    //any(): 全副扫描
    //none(): 不扫描
    //withClassAnnotation(): 扫描类上有指定的类注解的类,参数是一个类注解,如 "RestContrller.class"
    //withMethodAnnotation(): 扫描办法上有指定的注解的办法,参数如 "GetMapping.class"
    .api(RequestHandlerSelectors.basePackage("com.noel.swagger.controller"))
    //paths(): 过滤某些门路, 参数为正则匹配参数
    .paths(PathSelectors.ant("/omit/**"))
    .build();

只心愿在开发环境中应用 swagger,然而生产环境不应用:

@Bean
public Docket docket(Environment environment){
    //dev: application-dev.yml or application-anotherEnv.yml 或者相似的 properties 配置文件
    // 如果容许时加载了指定的环境,则返回 true
    Profiles profiles = Profiles.of("dev","anotherEnv");
    Boolean isSwaggerOn = environment.acceptsProfiles(profiles);
    return new Docket(DocumentationType.SWAGGER_2)
        .apiInfo(this.apiInfo())
        .enable(isSwaggerOn);
}

配置 API 文档分组:

.group("groupName")

配置多个分组:

@Bean
public Docket docketGroupA(){return new Docket(DocumentationType.SWAGGER_2).groupName("A");
}
@Bean
public Docket docketGroupB(){return new Docket(DocumentationType.SWAGGER_2).groupName("B");
}
@Bean
public Docket docketGroupB(){return new Docket(DocumentationType.SWAGGER_2).groupName("C");
}

在配置类中,一个 Docket Bean 实例,对应一个 swagger 分组。

4、罕用注解

4.1、接口类的注解

注解名称 阐明
@Api(tags=” 模块阐明 ”) 作用在 API 接口类 Controller 上,阐明该类的用处
@ApiOperation(“APPI 接口阐明 ”) 在 API 接口办法上进行阐明
@ApiImplicitParams 接口的参数阐明,用于对多个参数进行阐明
@ApiImplicitParam(“ 参数阐明 ”) 给接口参数增加阐明,用于对单个参数进行阐明
@ApiResponses; @ApiResponse 办法返回值的阐明,@ApiResponses 对多个返回值阐明

4.1.1、接口类的应用

@Api:放在 申请的类上,与 @Controller 并列,阐明类的作用,如用户模块,订单类等。

@Api 的属性

属性名称 阐明
value controller 若指定了 RequestMapping 拜访地址,把门路赋值给 value
tags 增加标签
description 形容
basePath 根本门路,基本上很少用
position swagger-ui 中的显示程序
produces 指明生成 json、xml 等格局,值为“application/json”
consumes 应用 json 或者 xml, 同上
protocols 协定类型,如: http, https, ws, wss.
authorizations 高级个性认证时配置
hidden 配置为 true,将在文档中暗藏

示例:

@Api(value="/test", tags="测试接口")
@Controller
@RequestMapping("/test")
public class TestController{}

4.1.2、接口办法应用的注解阐明

@ApiOperation:” 用在申请的办法上,阐明办法的作用 ”
@ApiImplicitParams:用在申请的办法上,蕴含一组参数阐明
@ApiImplicitParam:对单个参数的阐明
name:参数名
value:参数的阐明、形容
required:参数是否必须必填
paramType:参数放在哪个中央
query –> 申请参数的获取:@RequestParam
header –> 申请参数的获取:@RequestHeader
path(用于 restful 接口)–> 申请参数的获取:@PathVariable
body(申请体)–> @RequestBody User user
form(一般表单提交 )
dataType:参数类型,默认 String,其它值 dataType=”int”
defaultValue:参数的默认值
@ApiResponses:办法返回对象的阐明
@ApiResponse:每个参数的阐明
code:数字,例如 400
message:信息,例如 ” 申请参数没填好 ”
response:抛出异样的类

示例:

@ApiOperation(value="登录",notes="这是一个登录接口的阐明")
@ApiImplicitParams({@ApiImplicitParam(name="name",value="姓名",required=true,paramType="form",dataType="String"),
    @ApiImplicitParam(name="age",value="年龄",required=true,paramType="form",dataType="int")
})
@ApiResponses({@ApiResponse(code = 200, message = "申请胜利"),
    @ApiResponse(code = 400, message = "申请参数没填好"),
    @ApiResponse(code = 404, message = "申请门路没有或页面跳转门路不存在")
}) 
@ResponseBody
@PostMapping("/login")
public JsonResult login(@RequestParam String name, @RequestParam Integer age){
    //...
    return JsonResult.ok(map);
}

4.2、实体类的注解

注解名称 阐明
@ApiModel(“POJO 阐明 ”) 给模型类 JAVABEAN 等增加阐明
@ApiModelProperty(“POJO 模型类属性阐明 ”) 给类属性增加阐明

@ApiModel 的用处有 2 个:
当申请数据形容,即 @RequestBody 时,用于封装申请(包含数据的各种校验)数据;
当响应值是对象时,即 @ResponseBody 时,用于返回值对象的形容

@ApiModel 的属性:

注解名称 默认值 阐明
value 类名 提供中文阐明
description “” 形容
parent Void.class 为模型提供父类,用来形容继承关系
discriminatory “” 反对模型继承和多态,应用鉴别器的字段的名称,能够断言须要应用哪个子类型
subTypes [{},…] 继承此类的子类数组
reference “” 指定对应类型定义的援用,笼罩指定的任何其余元数据

@ApiModelProperty 的属性阐明:

注解名称 默认值 阐明
value “” 属性简要阐明
name “” 运行笼罩属性的名称。重写属性名称
allowableValues “” 限度参数可接管的值,固定取值,固定范畴
access “” 过滤属性,参阅:io.swagger.core.filter.SwaggerSpecFilter
notes “” 备注
dataType “” 参数的数据类型,能够是类名或原始数据类型,此值将笼罩从类属性读取的数据类型
required false 是否为必传参数,false: 非必传参数; true: 必传参数
position 0 容许在模型中显示排序属性
hidden false 暗藏模型属性,false: 不暗藏; true: 暗藏
example “” 属性的示例值
readOnly false 指定模型属性为只读,false: 非只读; true: 只读
reference “” 指定对应类型定义的援用,笼罩指定的任何其余元数据
allowEmptyValue false 容许传空值,false: 不容许传空值; true: 容许传空值

示例:

@ApiModel("用户")
Public class User{@ApiModelProperty("年龄")
    public Integer age;
    
    @ApiModelProperty(value="姓名", required=true)
    public String name;
}
正文完
 0