SpringMVC 數(shù)據(jù)校驗(yàn)方法(必看篇)
數(shù)據(jù)校驗(yàn)在web應(yīng)用里是非常重要的功能,尤其是在表單輸入中。在這里采用Hibernate-Vapdator進(jìn)行校驗(yàn),該方法實(shí)現(xiàn)了JSR-303驗(yàn)證框架支持注解風(fēng)格的驗(yàn)證。
一、導(dǎo)入jar包
若要實(shí)現(xiàn)數(shù)據(jù)校驗(yàn)功能,需要導(dǎo)入必要的jar包,主要包括以下幾個(gè):
classmate-1.3.1.jar
hibernate-vapdator-5.4.1.Final.jar
hibernate-vapdator-annotation-processor-5.4.1.Final.jar
hibernate-vapdator-cdi-5.4.1.Final.jar
jboss-logging-3.3.0.Final.jar
vapdation-api-1.1.0.Final.jar
二、常用的校驗(yàn)注解
| 注解 | 功能 |
|---|---|
| @Null | 驗(yàn)證對(duì)象是否為 null |
| @NotNull | 驗(yàn)證對(duì)象是否不為 null |
| @AssertTrue | 驗(yàn)證 Boolean 對(duì)象是否為 true |
| @AssertTrue | 驗(yàn)證 Boolean 對(duì)象是否為 false |
| @Max(value) | 驗(yàn)證 Number 和 String 對(duì)象是否小于等于指定值 |
| @Min(value) | 驗(yàn)證 Number 和 String 對(duì)象是否大于等于指定值 |
| @DecimalMax(value) | 驗(yàn)證注解的元素值小于等于 @DecimalMax 指定的 value 值 |
| @DecimalMin(value) | 驗(yàn)證注解的元素值大于等于 @DecimalMin 指定的 value 值 |
| @Digits(integer,fraction) | 驗(yàn)證字符串是否符合指定格式的數(shù)字,integer 指定整數(shù)精度,fraction 指定小數(shù)精度 |
| @Size(min,max) | 驗(yàn)證對(duì)象長(zhǎng)度是否在給定的范圍內(nèi) |
| @Past | 驗(yàn)證 Date 和 Calendar 對(duì)象是否在當(dāng)前時(shí)間之前 |
| @Future | 驗(yàn)證 Date 和 Calendar 對(duì)象是否在當(dāng)前時(shí)間之后 |
| @Pattern | 驗(yàn)證 String 對(duì)象是否符合正則表達(dá)式的規(guī)則 |
| @NotBlank | 檢查字符串是不是 Null,被 Trim 的長(zhǎng)度是否大于0,只對(duì)字符串,且會(huì)去掉前后空格 |
| @URL | 驗(yàn)證是否是合法的 url |
| 驗(yàn)證是否是合法的郵箱 | |
| @CreditCardNumber | 驗(yàn)證是否是合法的信用卡號(hào) |
| @Length(min,max) | 驗(yàn)證字符串的長(zhǎng)度必須在指定范圍內(nèi) |
| @NotEmpty | 檢查元素是否為 Null 或 Empty |
| @Range(min,max,message) | 驗(yàn)證屬性值必須在合適的范圍內(nèi) |
三、修改實(shí)體類
在類的屬性上進(jìn)行標(biāo)注,如:
public class User {
@NotBlank(message = "Username can not be empty")
private String username;
@NotBlank(message = "password can not be blank")
@Length(min = 6, max = 16, message = "The length of the password must be between 6 and 16 bits")
private String password;
@Range(min = 18, max = 60, message = "Age must be between 18 and 60 years old")
private Integer age;
@Pattern(regexp = "^1[3|4|5|7|8][0-9]{9}$", message = "Please enter the correct format of the phone number")
private String phone;
@Email(message = "Please enter a valid email address")
private String email;
// other...
}
四、修改相應(yīng)的處理方法
@RequestMapping(value = "/register")
public String register(@Valid @ModelAttribute("user") User user, Errors errors,Model model) {
if(errors.hasErrors()){
return "register";
}
model.addAttribute("user", user);
return "success";
}
五、視圖輸出
校驗(yàn)之后,我們通常需要在表單的輸入框后進(jìn)行文字反饋:
<form:form modelAttribute="user" method="post" action="register">
<fieldset>
<legend>register</legend>
<p>
<label>name:</label>
<form:input path="username" />
<form:errors path="username" cssStyle="color:red"/>
</p>
...
</fieldset>
</form:form>
然而,有些時(shí)候并不推薦直接將錯(cuò)誤信息寫在注解的message屬性里,這樣不方便國(guó)際化。因此可以做以下幾處修改:
1. 新建validatemessages.properties
username.not.blank = "username cannot be empty..." password.not.blank = "password cannot be empty" password.not.length = "password should be in 6-10" age.not.range = "age should be in 10-70" phone.not.pattern = "phone should be in format" email.not.format = "email should be in format"
2. 實(shí)體類中的注解使用相對(duì)引用
public class User {
@NotBlank(message = "{username.not.blank}")
private String username;
@NotBlank(message = "{password.not.blank}")
@Length(min = 6, max = 10, message = "{password.not.length}")
private String password;
@Range(min = 10, max = 70, message = "{age.not.range}")
private Integer age;
@Pattern(regexp = "^1[3|4|5|7|8][0-9]{9}$", message = "{phone.not.pattern}")
private String phone;
@Email(message = "{email.not.format}")
private String email;
// other...
}
3. 修改配置文件
<!-- 默認(rèn)的注解映射的支持 -->
<mvc:annotation-driven validator="validator" conversion-service="conversion-service" />
<bean id="validator" class="org.springframework.validation.beanvalidation.LocalValidatorFactoryBean">
<property name="providerClass" value="org.hibernate.validator.HibernateValidator"/>
<!--不設(shè)置則默認(rèn)為classpath下的 ValidationMessages.properties -->
<property name="validationMessageSource" ref="validatemessageSource"/>
</bean>
<bean id="conversion-service" class="org.springframework.format.support.FormattingConversionServiceFactoryBean" />
<bean id="validatemessageSource" class="org.springframework.context.support.ReloadableResourceBundleMessageSource">
<property name="basename" value="classpath:validatemessages"/>
<property name="fileEncodings" value="utf-8"/>
<property name="cacheSeconds" value="120"/>
</bean>
特別注意:value="classpath:validatemessages",文件名不加后綴!
至此,數(shù)據(jù)校驗(yàn)的整個(gè)過程就結(jié)束了。
最后還要特別強(qiáng)調(diào)的重點(diǎn)是:
視圖中<form:form modelAttribute="contentModel" method="post">的modelAttribute="xxx"后面的名稱xxx必須與對(duì)應(yīng)的@Valid @ModelAttribute("xxx") 中的xxx名稱一致,否則模型數(shù)據(jù)和錯(cuò)誤信息都綁定不到。
<form:errors path="name"></form:errors>即會(huì)顯示模型對(duì)應(yīng)屬性的錯(cuò)誤信息,當(dāng)path="*"時(shí)則顯示模型全部屬性的錯(cuò)誤信息。
以上這篇SpringMVC 數(shù)據(jù)校驗(yàn)方法(必看篇)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot?2.7.18?集成?Mybatis?Plus?+?Druid的實(shí)例詳解
Mybatis和MybatisPlus都是流行的持久層框架,MybatisPlus在Mybatis基礎(chǔ)上增加了更多便捷的功能,如自動(dòng)CRUD、分頁插件等,文章還提到了Entity、Mapper、Service、Controller等組件的基本使用方法,為開發(fā)者提供了一套完整的集成方案2024-10-10
Java之不通過構(gòu)造函數(shù)創(chuàng)建一個(gè)對(duì)象問題
這篇文章主要介紹了Java之不通過構(gòu)造函數(shù)創(chuàng)建一個(gè)對(duì)象問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03
詳解Java中使用泛型實(shí)現(xiàn)快速排序算法的方法
這篇文章主要介紹了Java中使用泛型實(shí)現(xiàn)快速排序算法的方法,快速排序的平均時(shí)間復(fù)雜度為(n\log n),文中的方法立足于基礎(chǔ)而并沒有考慮優(yōu)化處理,需要的朋友可以參考下2016-05-05
spring?@Scheduled注解各參數(shù)使用以及定時(shí)任務(wù)詳解
文章詳細(xì)介紹了Spring框架中@Scheduled注解的各個(gè)參數(shù),包括cron表達(dá)式、時(shí)區(qū)、fixedDelay、fixedRate、initialDelay等,并提供了多個(gè)示例來說明這些參數(shù)的使用方法2024-11-11
Java如何根據(jù)實(shí)體指定字段值對(duì)其List進(jìn)行排序詳解
在Java項(xiàng)目中可能會(huì)遇到給出一些條件,將List元素按照給定條件進(jìn)行排序的情況,這篇文章主要給大家介紹了關(guān)于Java如何根據(jù)實(shí)體指定字段值對(duì)其List進(jìn)行排序的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-07-07

