3.12 包含请求参数
温馨提醒
1、增强功能需要通过配置yml配置文件开启增强,自2.0.6开始
knife4j:
enable: true
2、自Knife4j 4.0版本,开发者必须使用knife4j-openapi2-spring-boot-starter
组件才生效
3、该特性自4.0版本后后续版本不在提供支持
在实际开发中,Knife4j提供了忽略参数的特性,这帮助开发者在某些场景中大大提高文档的可变性操作
但有时候需要忽略的参数太多时,我们需要写很多的忽略参数属性,此时,一个与忽略参数对立取反的特性就显得很有帮助了
使用自定义增强注解ApiOperationSupport
中的includeParameters
属性,可以强制包含要显示的参数.去除多余的参数显示
include的规则如下:
- 例如新增接口时,某实体类不需要显示Id,即可使用该属性对参数进行忽略.
includeParameters={"id"}
- 如果存在多个层次的参数包含关系,则使用名称.属性的方式,例如
includeParameters={"uptModel.id","uptModel.uptPo.id"}
,其中uptModel是实体对象参数名称,id为其属性,uptPo为实体类,作为uptModel类的属性名称 - 一般是form表单类的请求,不需要设置参数名称,直接给定属性值名称即可
3.12.1 表单请求
简单请求比较简单,一般以formdata或者x-www-form-urlencoded类型的请求居多,针对这种请求的参数包含关系,我们在开发中只需要直接写上相应的属性名称即可
代码示例如下:
@ApiOperationSupport(order = 40,includeParameters = {"ignoreLabels","longUser.ids"})
@ApiOperation(value = "包含参数值-Form类型1")
@PostMapping("/ex1c")
public Rest<IgnoreP1> findAllc12(IgnoreP1 ignoreP1) {
Rest<IgnoreP1> r=new Rest<>();
r.setData(ignoreP1);
return r;
}
IgnoreP1.java
如下:
public class IgnoreP1 {
@ApiModelProperty(value = "姓名a啊",example = "你好")
private String name;
@ApiModelProperty(value = "用户列表")
private LongUser longUser;
@ApiModelProperty(value = "标签集合")
private List<IgnoreLabel> ignoreLabels;
//getter and setter...
}
3.12.2 JSON请求
JSON请求相比较简单请求有一个区别,需要把一级参数名称带上
代码示例如下:
@ApiOperationSupport(order = 42,includeParameters = {"ignoreP1.ignoreLabels.code","ignoreP1.longUser.ids"})
@ApiOperation(value = "包含参数值-JSON类型1")
@PostMapping("/exc3")
public Rest<IgnoreP1> findAllc3(@RequestBody IgnoreP1 ignoreP1) {
Rest<IgnoreP1> r=new Rest<>();
r.setData(ignoreP1);
return r;
}
在上面的代码示例中,是一个标准的JSON请求应用,ignoreP1
就是参数名称,在包含该JSON下的某些属性时,必须在includeParameters
属性中指明
例如:ignoreP1.longUser.ids