ssm整合 hibernate的validation验证框架

在前端验证表单可以最大程度的提升用户体验,缺点很明显:想搞事情的同学,非常轻松就能绕过前端校验。那么对应的后端校验就显得尤为重要了。笔者作为一个很懒的程序员新手,无意之间发现hibernate的validation验证框架,感觉非常好,极大程度的减少代码量,特此记录一下。

1引入jar(hibernate的validation验证框架并不是hibernate框架)


 
      org.hibernate
      hibernate-validator
      6.0.13.Final
    

    
    
      javax.validation
      validation-api
      2.0.1.Final
    

2.springMvc.xml配置


    
        
        


    

3.创建pojo类

package com.dingdaoshop.dao.pojo;

import javax.validation.constraints.Min;
import javax.validation.constraints.NotNull;
import javax.validation.constraints.Pattern;
import javax.validation.constraints.Size;

import org.hibernate.validator.constraints.*;




public class User {
	
	
	@NotNull(message="用户名不能为空")
	@Size(min=6,max=18,message="用户名的长度错误,请填写6-18位")
	public String name;
	
	@NotNull(message="密码不能为空!")
	@Size(min=6,max=18,message="密码的长度错误,请填写6-18位")
	
	public String password;
	

	
	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	

	
	

	public String getPassword() {
		return password;
	}

	public void setPassword(String password) {
		this.password = password;
	}
}

4.controller类(BindingResult要紧跟在@Valid之后,即验证类之后)

@RequestMapping(value="/login.do",method=RequestMethod.GET)
	public String login(@Valid @ModelAttribute("user") User user,BindingResult bindingResult,HttpSession session,HttpServletRequest request) {
		System.out.println(user.name);
		if (bindingResult.hasErrors()) {
			List list = bindingResult.getFieldErrors();
			for (ObjectError objectError :list){
		        // 输出错误信息
		        System.out.println(objectError.getDefaultMessage());
		        
		    }
			request.setAttribute("allErrors", list);
			return "login";
		}else {
			//处理业务逻辑
			System.out.println("没有错误?");
		}
		return "jsp/table_complete";
	}

5.前端页面

<%@taglib prefix="c"  uri="http://java.sun.com/jsp/jstl/core"%>
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>








	
	    ${ error.defaultMessage}

Hello World!



6.运行截图

ssm整合 hibernate的validation验证框架_第1张图片

7.验证规则

@AssertTrue 用于boolean字段,该字段只能为true  
@AssertFalse 该字段的值只能为false
@CreditCardNumber 对信用卡号进行一个大致的验证
@DecimalMax 只能小于或等于该值
@DecimalMin 只能大于或等于该值
@Digits(integer=,fraction=) 检查是否是一种数字的整数、分数,小数位数的数字
@Email 检查是否是一个有效的email地址
@Future 检查该字段的日期是否是属于将来的日期
@Length(min=,max=) 检查所属的字段的长度是否在min和max之间,只能用于字符串
@Max 该字段的值只能小于或等于该值
@Min 该字段的值只能大于或等于该值
@NotNull 不能为null
@NotBlank 不能为空,检查时会将空格忽略
@NotEmpty 不能为空,这里的空是指空字符串
@Null 检查该字段为空
@Past 检查该字段的日期是在过去
@Pattern(regex=,flag=) 被注释的元素必须符合指定的正则表达式
@Range(min=,max=,message=) 被注释的元素必须在合适的范围内
@Size(min=, max=) 检查该字段的size是否在min和max之间,可以是字符串、数组、集合、Map等
@URL(protocol=,host,port) 检查是否是一个有效的URL,如果提供了protocol,host等,则该URL还需满足提供的条件
@Valid 该注解主要用于字段为一个包含其他对象的集合或map或数组的字段,或该字段直接为一个其他对象的引用,这样在检查当前对象的同时也会检查该字段所引用的对象

这就完成了,如此简单,实体类上面加上注解后端验证就搞定了,等笔者有时间会增加表单分组验证~

你可能感兴趣的:(SSM)