处理静态资源
SpringMVC数据绑定流程
数据转换
自定义类型转换器
自定义转换器实例
1.新建自定义转换器
EmployeeConverter
package com.atguigu.springmvc.conterters;
import org.springframework.core.convert.converter.Converter;
import org.springframework.stereotype.Component;
import com.atguigu.springmvc.crud.entities.Department;
import com.atguigu.springmvc.crud.entities.Employee;
/**
* 自定义转换器,将前台页面传进来的employee字符串转换为Employee对象
* @author lxf
*/
@Component
public class EmployeeConverter implements Converter<String, Employee> {
/**
* source 字符串格式:GG-gg@atguigu.com-0-105
*/
@Override
public Employee convert(String source) {
// TODO Auto-generated method stub
if(source != null)
{
String[] vals = source.split("-");
if(vals != null && vals.length ==4)
{
String lastName = vals[0];
String email = vals[1];
Integer gender = Integer.parseInt(vals[2]);
Department department = new Department();
department.setId(Integer.parseInt(vals[3]));
Employee employ = new Employee(null, lastName, email, gender, department);
System.out.println(source + "--convert--" + employ);
return employ;
}
}
return null;
}
}
- 新建Controller
SpringMVCTestNew
@Controller
public class SpringMVCTestNew {
@Autowired
private EmployeeDao employDao ;
@RequestMapping("/testRest")
public String testRest()
{
System.out.println("hellow testRest");
return "redirect:/emps";
}
@RequestMapping(value="/testConversionServiceConverer")
public String testConverter(@RequestParam(value="employee") Employee employee)
{
System.out.println("testConverter param employee String to Employee Obj =" + employee);
employDao.save(employee);
return "redirect:/emps";
}
}
3.配置 springmvc.xml
<!-- 配置以上可以访问静态资源后,保证正常controller依然可以正常访问,需要配置mvc:annotation-driven -->
<mvc:annotation-driven conversion-service="conversionService"></mvc:annotation-driven>
<!-- 配置conversionService -->
<bean id="conversionService" class="org.springframework.context.support.ConversionServiceFactoryBean">
<property name="converters">
<set>
<ref bean="employeeConverter"/>
</set>
</property>
</bean>
4.jsp页面编写表单
<form action="testConversionServiceConverer" method="POST">
<!-- lastname-email-gender-department.id 例如: GG-gg@atguigu.com-0-105 -->
Employee: <input type="text" name="employee"/>
<input type="submit" value="Submit"/>
</form>
5.在浏览器中浏览jsp页面
6.提交后后台输出:
aa-aa@163.com-1-103--convert--Employee [id=null, lastName=aa, email=aa@163.com, gender=1, department=Department [id=103, departmentName=null], birth=null, salary=null]
testConverter param employee String to Employee Obj =Employee [id=null, lastName=aa, email=aa@163.com, gender=1, department=Department [id=103, departmentName=null], birth=null, salary=null]
关于 `mvc:annotation-driven' 配置
通过以上可知,RequestMappingHandlerAdapter
是负责处理RequestMapping
映射的
@InitBinder
注解应用
控制器修改
/**
* 不自动将前台表单数据绑定到对应的bean的lastName属性, 需要我们自行处理
* @param binder
*/
@InitBinder
public void initBinder(WebDataBinder binder){
binder.setDisallowedFields("lastName");
}
数据格式化
-
日期格式化
-
数值格式化
-
格式化示例
数据校验
springMVC数据校验
<mvc:annotation-driven/> 会默认装配好一个
LocalValidatorFactoryBean
,通过在处理方法的入参上标注 @valid 注解即可让 Spring MVC 在完成数据绑定后执行数据校验的工作在已经标注了 JSR303 注解的表单/命令对象前标注一个@Valid,Spring MVC 框架在将请求参数绑定到该入参对象后,就会调用校验框架根据注解声明的校验规则实施校验
Spring MVC 是通过对处理方法签名的规约来保存校验结果的:前一个表单/命令对象的
校验结果
保存到随后的入参中,这个保存校验结果的入参必须是BindingResult
或Errors
类型,这两个类都位于org.springframework.validation
包中需校验的 Bean 对象和其绑定结果对象或错误对象时成对出现的,它们
之间不允许声明其他的入参Errors 接口提供了获取错误信息的方法,如 getErrorCount() 或
getFieldErrors(String field)-
BindingResult 扩展了 Errors 接口
在表单/命令对象类的属性中标注校验注解,在处理方法对应的入参前添加
@Valid
,Spring MVC 就会实施校验并将校验结果保存在被校验入参对象之后的BindingResult
或Errors
入参中。-
常用方法:
- FieldError getFieldError(String field)
- List<FieldError> getFieldErrors()
- Object getFieldValue(String field)
- Int getErrorCount()
-
需要的jar包
错误信息显示在jsp页面上
springMVC将验证后错误信息除了放到BindingRequest中,还会放到"隐含模型中", 隐含模型中的所有数据最终将通过 HttpServletRequest 的属性列表暴露给 JSP 视图对象,因此在 JSP 中可以获取错误信息-
可以定制错误显示信息,通过国际化配置文件
i18n.properties
, 同时需要在springmvc.xml
中配置引入该文件
-
举例: