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

這就完成了,如此簡單,實體類上面加上註解後端驗證就搞定了,等筆者有時間會增加表單分組驗證~

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章