SpringMVC中的参数绑定有两种方法:InitBinder和Convert
后者我们已经很熟知了,这里大概写一下其用法
@Component
public class MyConvert implements Converter<String, ConstantEnum> {
@Override
public ConstantEnum convert(String code) {
if (Integer.parseInt(code) == 1001) return ConstantEnum.UNCHECK;
if (Integer.parseInt(code) == 1002) return ConstantEnum.CHECKED;
return null;
}
}
@GetMapping("/enum")
public String testConvert(@RequestParam("code") ConstantEnum constantEnum){
return constantEnum.getMsg();
}
这样我们前端传值字符串code="1001"
和code="1002"
时会自动转换为ConstantEnum
InitBinder
InitBinder的基础是 PropertyEditor,这是由jdk提供的由字符串转为对象的功能,spring对其进行了扩展PropertyEditorSupport并提供了很多默认实现
InitBinder
与Convert
的不同是,InitBinder
的作用范围只在定义的Controller
内,对于其他Controller
的请求不会起作用
@InitBinder
public void convert(WebDataBinder binder){
//这里指定你要注册的类型转换器和对应的要转换的类型
binder.registerCustomEditor(ConstantEnum.class,new MyCustomPropEditer());
}
public class MyCustomPropEditer extends PropertyEditorSupport {
@Override
public String getAsText() {
ConstantEnum constantEnum = (ConstantEnum) getValue();
return constantEnum.getMsg();
}
//这里写了参数绑定时的主要转换逻辑
@Override
public void setAsText(String text) throws IllegalArgumentException {
setValue(ConstantEnum.convertBean(text));
}
}
@GetMapping("/enum")
public String testConvert(@RequestParam("code") ConstantEnum constantEnum){
return constantEnum.getMsg();
}
当两者同时存在时,优先使用InitBinder
两者区别
使用InitBinder
,仅在当前控制器有效;使用Convert
,对所有控制器有效;
对于通用的如日期转换,使用Convert
更方便;
对于一些比较复杂的用的地方很少的,使用InitBinder
更佳,因为如果写到Convert
每次请求都会来判断是否要转换,这是不必要的操作