在前端驗證表單可以最大程度的提升用戶體驗,缺點很明顯:想搞事情的同學,非常輕鬆就能繞過前端校驗。那麼對應的後端校驗就顯得尤爲重要了。筆者作爲一個很懶的程序員新手,無意之間發現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地址 | |
@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
這就完成了,如此簡單,實體類上面加上註解後端驗證就搞定了,等筆者有時間會增加表單分組驗證~