第一步:导入包
hibernate-validator-5.4.1.Final.jar
jboss-logging-3.1.4.CR2.jar
validation-api-1.1.0.GA.jar
第二步:给bean需要验证的属性增加相应的效验注解,注解如下:
第三步:在Controller层使用注解所声明的限制规则来进行数据的效验
在方法入参标注@valid注解
后面跟BindingResult参数
注意:
@valid注解标示的参数后面,必须紧挨一个BindingResult参数,否则Spring会在效验不通过时直接抛出异常
@RequestMapping("/hello")
public ModelAndView index(HttpServletRequest request, @Valid Bbs_User user, BindingResult bindingResult){
if(bindingResult.hasErrors()){ //如果bindingResult里有异常信息
return new ModelAndView("hello");
}else {
ApplicationContext context = getApplicatIonContext(request);
DetailService dsi = (DetailService) context.getBean("detailServiceImpl");
第四步:jsp页面用取异常信息
<%@ taglib prefix="fm" uri="http://www.springframework.org/tags/form" %>
<fm:errors path="bbs_User.userName"/><br/>
自定义异常
${ex.message}
自定义效验:
1,新建类 实现 org.springframework.validation.Validator接口
实现public void validate(Object o, Errors errors) 方法
o:是pojo对象
public class UserValidator implements Validator {
@Override
public boolean supports(Class<?> aClass) {
//类型比较
return Bbs_User.class.getName().equals(aClass.getName());
}
@Override
public void validate(Object o, Errors errors) {
Bbs_User user=(Bbs_User)o;
if(user.getBbsName().charAt(0)=='a'){
errors.rejectValue("bbsName","姓名不能以a开关");
}
}
}
2.1,在controller层编写,只对当前控制类有效
@Controller
@RequestMapping("/user") // "/user" 访问URL
public class IndexController extends BasDao {
@InitBinder
public void initBinder(DataBinder binder){
binder.setValidator(new UserValidator());
}
@RequestMapping("/indextwo")
//加上@Valid注解,后面加上BindingResult参数
public String index( @Valid Bbs_User bbs_user , BindingResult bindingResult,HttpServletRequest request){
if(bindingResult.hasErrors()){ //如果bindingResult里有异常信息
List<ObjectError> lsit=bindingResult.getAllErrors();
for(int i=0;i< lsit.size();i++){
System.out.println(lsit.get(i));
}
return "jsp/exception";
}else {
}
2.2,在配置文件配置,对所有有效
<bean class="cn.kgc.pojo.UserValidator" id="userValidator"/>
<mvc:annotation-driven validator="userValidator"/>