SpringMVC 使用JSR-303進行校驗 @Valid

使用註解css

1、準備校驗時使用的JARhtml

validation-api-1.0.0.GA.jar:JDK的接口;java

hibernate-validator-4.2.0.Final.jar是對上述接口的實現;git

log4j、slf4j、slf4j-log4j正則表達式

2、編寫須要校驗的beanspring

@NotNull(message="名字不能爲空")private String userName;
@Max(value=120,message="年齡最大不能查過120")private int age;
@Email(message="郵箱格式錯誤")private String email;

3、校驗方法api

@RequestMapping("/login")     
public String testValid(@Valid User user, BindingResult result){         
    if (result.hasErrors()){             
        List<ObjectError> errorList = result.getAllErrors();             
        for(ObjectError error : errorList){                 
            System.out.println(error.getDefaultMessage());             
        }         
    }                     
         return "test";     
 }

備註:這裏一個@Valid的參數後必須緊挨着一個BindingResult 參數,不然spring會在校驗不經過時直接拋出異常數組

 

前臺可使用spring的標籤庫也能夠本身自定義處理mvc

spring標籤庫的用法:app


<%@ taglib prefix="form" uri="http://www.springframework.org/tags/form"%>       <html>    <head>    <title>Reservation Form</title>    <style>    .error {        color: #ff0000;        font-weight: bold;    }    </style>    </head>       <body>        <form:form method="post" modelAttribute="vm">            <form:errors path="*" cssClass="error" />            <table>                <tr>                    <td>Name</td>                    <td><form:input path="userName" />                    </td>                    <td><form:errors path="userName" cssClass="error" />                    </td>                </tr>                <tr>                    <td>email</td>                    <td><form:input path="email" />                    </td>                    <td><form:errors path="email" cssClass="error" />                    </td>                </tr>                        <tr>                    <td colspan="3"><input type="submit" />                    </td>                </tr>            </table>        </form:form>    </body>    </html>

 

4、開啓spring的Valid功能

<mvc:annotation-driven />

 

5、JSR303定義的校驗類型

複製代碼

空檢查

@Null       驗證對象是否爲null

@NotNull    驗證對象是否不爲null, 沒法查檢長度爲0的字符串

@NotBlank 檢查約束字符串是否是Null還有被Trim的長度是否大於0,只對字符串,且會去掉先後空格.

@NotEmpty 檢查約束元素是否爲NULL或者是EMPTY.

 

Booelan檢查

@AssertTrue     驗證 Boolean 對象是否爲 true  

@AssertFalse    驗證 Boolean 對象是否爲 false  

 

長度檢查

@Size(min=, max=) 驗證對象(Array,Collection,Map,String)長度是否在給定的範圍以內  

@Length(min=, max=) Validates that the annotated string is between min and max included.

 

日期檢查

@Past           驗證 Date 和 Calendar 對象是否在當前時間以前  

@Future     驗證 Date 和 Calendar 對象是否在當前時間以後  

@Pattern    驗證 String 對象是否符合正則表達式的規則

 

數值檢查,建議使用在Stirng,Integer類型,不建議使用在int類型上,由於表單值爲「」時沒法轉換爲int,但能夠轉換爲Stirng爲"",Integer爲null

@Min            驗證 Number 和 String 對象是否大等於指定的值  

@Max            驗證 Number 和 String 對象是否小等於指定的值  

@DecimalMax 被標註的值必須不大於約束中指定的最大值. 這個約束的參數是一個經過BigDecimal定義的最大值的字符串表示.小數存在精度

@DecimalMin 被標註的值必須不小於約束中指定的最小值. 這個約束的參數是一個經過BigDecimal定義的最小值的字符串表示.小數存在精度

@Digits     驗證 Number 和 String 的構成是否合法  

@Digits(integer=,fraction=) 驗證字符串是不是符合指定格式的數字,interger指定整數精度,fraction指定小數精度。

 

@Range(min=, max=) Checks whether the annotated value lies between (inclusive) the specified minimum and maximum.

@Range(min=10000,max=50000,message="range.bean.wage")
private BigDecimal wage;

 

@Valid 遞歸的對關聯對象進行校驗, 若是關聯對象是個集合或者數組,那麼對其中的元素進行遞歸校驗,若是是一個map,則對其中的值部分進行校驗.(是否進行遞歸驗證)

@CreditCardNumber信用卡驗證

@Email  驗證是不是郵件地址,若是爲null,不進行驗證,算經過驗證。

@ScriptAssert(lang= ,script=, alias=)

@URL(protocol=,host=, port=,regexp=, flags=)

複製代碼

 

六、自定義校驗類型

能夠參考:http://exceptioneye.iteye.com/blog/1305040

 

使用接口

能夠參考:http://elf8848.iteye.com/blog/1299587

相關文章
相關標籤/搜索