ssm整合 hibernate的validation验证框架

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

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

<!--数据验证-->
 <dependency>
      <groupId>org.hibernate</groupId>
      <artifactId>hibernate-validator</artifactId>
      <version>6.0.13.Final</version>
    </dependency>

    <!--validation api-->
    <dependency>
      <groupId>javax.validation</groupId>
      <artifactId>validation-api</artifactId>
      <version>2.0.1.Final</version>
    </dependency>

2.springMvc.xml配置

<!--验证器-->
    <bean id="validator" class="org.springframework.validation.beanvalidation.LocalValidatorFactoryBean">
        <!--注入hibernate的验证器-->
        <property name="providerClass"  value="org.hibernate.validator.HibernateValidator"/>
</bean>

    <mvc:annotation-driven  validator="validator"></mvc:annotation-driven>

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<FieldError> 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"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<script type="text/javascript" src="assets/js/jquery-2.1.0.js"></script>

<body>
<c:if test="${allErrors!=null }">
	<c:forEach items="${allErrors }" var="error">
	    ${ error.defaultMessage}<br/>
	</c:forEach>
</c:if>
<h2>Hello World!</h2>
<!-- <a href="testLogin">储存用户</a> -->
<!-- <a href="login.do">点击登录</a> -->
<form  action="login.do" method="get">
	<input type="text" name="name" id="name" value="${user.name }"><br>
	<input type="text" name="password" id="password" value="${user.password }"><br>
	<input type="submit" value="登录">
</form>
</body>


</html>

6.运行截图

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或数组的字段,或该字段直接为一个其他对象的引用,这样在检查当前对象的同时也会检查该字段所引用的对象

 

有需要服务器的小伙伴可以点击下面链接5折购买哦~

热卖云产品3折起,云服务器、云数据库特惠,服务更稳,速度更快,价格更优
https://cloud.tencent.com/act/cps/redirect?redirect=1014&cps_key=f960a09f2d06453a8d42a2063b49abc2&from=console

热卖云产品3折起,云服务器、云数据库特惠,服务更稳,速度更快,价格更优
https://cloud.tencent.com/act/cps/redirect?redirect=1014&cps_key=f960a09f2d06453a8d42a2063b49abc2&from=console

腾讯云服务器安全可靠高性能,多种配置5折出售:
https://cloud.tencent.com/act/cps/redirect?redirect=1001&cps_key=f960a09f2d06453a8d42a2063b49abc2&from=console

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

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值