认识Swagger
Swagger 是一个规范和完整的框架,用于生成、描述、调用和可视化 RESTful 风格的 Web 服务。总体目标是使客户端和文件系统作为服务器以同样的速度来更新文件的方法,参数和模型紧密集成到服务器端的代码,允许API来始终保持同步。
作用:接口的文档在线自动生成 ;功能测试。
说白了就是:1.实时更新API文档 2.提供功能测试(post方法不用再使用postman测试了,这个还是非常方便的)
Swagger 集成文档具有以下几个优势
- 功能丰富 :支持多种注解,自动生成接口文档界面,支持在界面测试API接口功能;
- 及时更新 :开发过程中花一点写注释的时间,就可以及时的更新API文档,省心省力;
- 整合简单 :通过添加pom依赖和简单配置,内嵌于应用中就可同时发布API接口文档界面,不需要部署独立服务。
如何使用Swagger
1.在pom.xml里面添加swagger 的maven依赖
<!--Swagger2相关的依赖-->
<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>
2.添加Swagger的配置类
@Configuration
@EnableSwagger2
public class SwaggerConfig {
// swagger开关,开发环境开启,生产环境关闭
@Value("${swagger.enabled}")
private boolean enableSwagger;
@Bean
public Docket createRestApi() {
return new Docket(DocumentationType.SWAGGER_2)
.apiInfo(apiInfo())
//是否开启 (true 开启 false隐藏。生产环境建议隐藏)
.enable(enableSwagger)
.select()
//扫描的路径包,设置basePackage会将包下的所有被@Api标记类的所有方法作为api
.apis(RequestHandlerSelectors.basePackage("com.springswagger.controller"))
//指定路径处理PathSelectors.any()代表所有的路径
.paths(PathSelectors.any())
.build();
}
/**
* @Description swagger基本信息
* @Param
* @return
* @Author zhen.ma
* @Date 2020.06.11 22:26
**/
private ApiInfo apiInfo() {
return new ApiInfoBuilder()
//设置文档标题(API名称)
.title("SpringBoot使用Swagger2构建restful Api文档")
//文档描述
.description("接口说明")
//服务条款URL
.termsOfServiceUrl("http://127.0.0.1:8080/")
//联系信息
.contact(new Contact("xiao.ge","http://xiao.ge.com","3311247943@qq.com"))
//版本号
.version("V1.0")
.build();
}
//swagger接口文档界面
//http://localhost:8080/swagger-ui.html
}
3.添加测试类控制器
@RestController
@RequestMapping("api/v1")
@Api(value = "测试接口", tags = "UserController", description = "测试接口相关")
public class MyController {
@GetMapping("/")
@ApiOperation(value = "访问网站首页", notes = "网站首页")
public void index() {
}
@GetMapping(value = "/mi", produces = "application/json")
@ApiImplicitParam(name = "num", value = "数字", required = true, dataType = "int", paramType = "query")
@ApiOperation(value = "一个数的平方", notes = "求一个数的平方")
public int getNum2(@RequestParam int num) {
return num*num;
}
}
api文档访问 http://localhost:8080/swagger-ui.html
常用注解说明:
swagger 通过注解接口生成文档,包括接口名,请求方法,参数,返回信息等。
@Api:用于controller类上,说明该类的作用
tags=“说明该类的作用,可以在UI界面上看到的注解”
value=“该参数没什么意义,在UI界面上也看到,所以不需要配置”
@ApiOperation:用在controller的方法上,用来说明方法用途、作用
value=“说明方法的用途、作用”
notes=“方法的备注说明”
@ApiImplicitParam:用来给方法入参增加说明
name:参数名
value:参数的汉字说明、解释
dataType: 参数类型,默认String
required : 参数是否必传,true必传
defaultValue:参数的默认值
paramType:参数放在哪个地方
header请求参数的获取:@RequestHeader,参数从请求头获取
query请求参数的获取:@RequestParam,参数从地址栏问号后面的参数获取
path(用于restful接口)请求参数的获取:@PathVariable,参数从URL地址上获取
body(不常用)参数从请求体中获取
form(不常用)参数从form表单中获取
@ApiImplicitParams:用在controller的方法上,一组@ApiImplicitParam
@ApiResponse:用在 @ApiResponses里边,一般用于表达一个错误的响应信息
code:数字,例如400
message:信息,例如"请求参数没填好"
response:抛出异常的类
@ApiResponses:用在controller的方法上,用于表示一组响应
@ApiModel:用在返回对象类上,描述一个Model的信息(这种一般用在post创建的时候,使用@RequestBody这样的场景,请求参数无法使用@ApiImplicitParam注解进行描述的时候)
@ApiModelProperty:用在出入参数对象的字段上,表示对model属性的说明或者数据操作更改
value = 字段说明
name = 重写属性名字
dataType = 重写属性类型
required = 是否必填,true必填
example = 举例说明
hidden = 隐藏
@ApiIgnore:使用该注解忽略这个API,不会生成接口文档。可注解在类和方法上