SpringMVC 第四篇【参数绑定详讲、默认支持参数类型、自定义参数绑定、RequestParam 注解】
参数绑定
我们在 Controller 使用方法参数接收值,就是把 web 端的值给接收到 Controller 中处理,这个过程就叫做参数绑定…
默认支持的参数类型
从上面的用法我们可以发现,我们可以使用 request 对象、Model 对象等等,其实是不是可以随便把参数写上去都行???其实并不是的…
Controller 方法默认支持的参数类型有 4 个,这 4 个足以支撑我们的日常开发了
- HttpServletRequest
- HttpServletResponse
- HttpSession
- Model
参数的绑定过程
一般地,我们要用到自定义的参数绑定就是上面所讲的日期类型转换以及一些特殊的需求…. 对于平常的参数绑定,我们是无需使用转换器的,SpringMVC 就已经帮我们干了这个活了…
自定义绑定参数【版本一】
在上一篇我们已经简单介绍了怎么把字符串转换成日期类型了【使用的是 WebDataBinder 方式】… 其实那是一个比较老的方法,我们可以使用 SpringMVC 更推荐的方式…
在上次把字符串转换成日期类型,如果使用的是 WebDataBinder 方式的话,那么该转换仅仅只能在当前 Controller 使用… 如果想要全部的 Controller 都能够使用,那么我们可以使用 WebBindingInitializer 方式
如果想多个 controller 需要共同注册相同的属性编辑器,可以实现 PropertyEditorRegistrar 接口,并注入 webBindingInitializer 中。
实现接口
public class CustomPropertyEditor implements PropertyEditorRegistrar {@Overridepublic void registerCustomEditors(PropertyEditorRegistry binder) {binder.registerCustomEditor(Date.class, new CustomDateEditor(new SimpleDateFormat("yyyy-MM-dd HH-mm-ss"), true));}}
配置转换器
注入到 webBindingInitializer 中
<!-- 注册属性编辑器 --><bean id="customPropertyEditor" class="cn.itcast.ssm.controller.propertyeditor.CustomPropertyEditor"></bean><!-- 自定义webBinder --><bean id="customBinder" class="org.springframework.web.bind.support.ConfigurableWebBindingInitializer"><!-- propertyEditorRegistrars用于属性编辑器 --><property name="propertyEditorRegistrars"><list><ref bean="customPropertyEditor" /></list></property></bean><!-- 注解适配器 --><bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"><!-- 在webBindingInitializer中注入自定义属性编辑器、自定义转换器 --><property name="webBindingInitializer" ref="customBinder"></property></bean>
自定义参数转换器【版本二】
上面的方式是对象较老的,现在我们一般都是实现 Converter 接口来实现自定义参数转换… 我们就来看看实现 Converter 比上面有什么好
配置日期转换器
public class CustomDateConverter implements Converter<String, Date> {@Overridepublic Date convert(String source) {try {//进行日期转换return new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").parse(source);} catch (Exception e) {e.printStackTrace();}return null;}}
配置去除字符串转换器
public class StringTrimConverter implements Converter<String, String> {@Overridepublic String convert(String source) {try {//去掉字符串两边空格,如果去除后为空设置为nullif(source!=null){source = source.trim();if(source.equals("")){return null;}}} catch (Exception e) {e.printStackTrace();}return source;}
}
从上面可以得出,我们想要转换什么内容,就直接实现接口,该接口又是支持泛型的,阅读起来就非常方便了…
配置转换器
<!-- 转换器 --> <bean id="conversionService"class="org.springframework.format.support.FormattingConversionServiceFactoryBean">
<property name="converters"><list><bean class="cn.itcast.ssm.controller.converter.CustomDateConverter"/><bean class="cn.itcast.ssm.controller.converter.StringTrimConverter"/></list>
</property>
</bean> <!-- 自定义webBinder --> <bean id="customBinder"class="org.springframework.web.bind.support.ConfigurableWebBindingInitializer"> <!-- 使用converter进行参数转 -->
<property name="conversionService" ref="conversionService"/>
</bean> <!-- 注解适配器 --> <bean
class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"> <!-- 在webBindingInitializer中注入自定义属性编辑器、自定义转换器 -->
<property name="webBindingInitializer" ref="customBinder"></property>
</bean>
如果是基于 `` 的话,我们是这样配置的
<mvc:annotation-driven conversion-service="conversionService">
</mvc:annotation-driven>
<!-- conversionService --><bean id="conversionService" class="org.springframework.format.support.FormattingConversionServiceFactoryBean"><!-- 转换器 --><property name="converters"><list><bean class="cn.itcast.ssm.controller.converter.CustomDateConverter"/><bean class="cn.itcast.ssm.controller.converter.StringTrimConverter"/></list></property></bean>
@RequestParam 注解
我们一般使用的参数绑定都有遵循的规则:方法参数名要与传递过来的 name 属性名相同。
在默认的情况下,只有名字相同,SpringMVC 才会帮我们进行参数绑定…
如果我们使用 @RequestParam注解
的话,我们就可以使方法参数名与传递过来的 name 属性名不同…
该注解有三个变量
- value【指定 name 属性的名称是什么】
- required【是否必须要有该参数】
- defaultvalue 设置默认值
例子:我们的方法参数叫 id,而页面带过来的 name 属性名字叫 item_id,一定需要该参数
public String editItem(@RequestParam(value="item_id",required=true) String id) {}