目前比較流行的驗證做法:前端jquery-form-validate + 後端hibernate-validate
在pom中添加相關jar:
<!-- use hibernate-validator to validate entity before enter controller -->
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-validator</artifactId>
<version>${hibernate.version}</version>
</dependency>
<dependency>
<groupId>javax.validation</groupId>
<artifactId>validation-api</artifactId>
<version>${validation.api.version}</version>
</dependency>
spring mvc中配置:
1 <!-- 國際化配置 --> 2 <bean id="localeResolver" class="org.springframework.web.servlet.i18n.CookieLocaleResolver" /> 3 <bean id="messageSource" class="org.springframework.context.support.ReloadableResourceBundleMessageSource"> 4 <property name="basenames"> 5 <list> 6 <value>classpath:resource/ValidationMessages</value> 7 </list> 8 </property> 9 <property name="useCodeAsDefaultMessage" value="true" /> 10 </bean> 11 12 13 <!-- 注冊驗證器 --> 14 <mvc:annotation-driven validator="validator" /> 15 16 <bean id="validator" class="org.springframework.validation.beanvalidation.LocalValidatorFactoryBean"> 17 <property name="providerClass" value="org.hibernate.validator.HibernateValidator" /> 18 <!--這裡配置將使用上面國際化配置的messageSource --> 19 <property name="validationMessageSource" ref="messageSource" /> 20 </bean>
配置錯誤信息:(當然也可以直接寫在javabean中)
1 val.age.message=\u5E74\u9F84\u4E0D\u80FD\u8D85\u8FC720\u5C81
2
3 username.not.null=\u7528\u6237\u540D\u4E0D\u80FD\u4E3A\u7A7A
4 pwd.not.null=\u5BC6\u7801\u4E0D\u80FD\u4E3A\u7A7A
5 username.length=\u7528\u6237\u540D\u6700\u5927\u4E0D\u80FD\u8D85\u8FC7{max},\u6700\u5C0F\u4E0D\u80FD\u5C11\u4E8E{min}
6
7 email.format.error=\u90AE\u7BB1\u683C\u5F0F\u4E0D\u6B63\u786E
8
9 title.not.null=\u63A8\u9001\u4E3B\u9898\u4E0D\u80FD\u4E3A\u7A7A
entity(setter getter 略):
1 public class ValBean {
2
3
4 /**
5 * Bean Validation 中內置的 constraint
6 * @Null 被注釋的元素必須為 null
7 * @NotNull 被注釋的元素必須不為 null
8 * @AssertTrue 被注釋的元素必須為 true
9 * @AssertFalse 被注釋的元素必須為 false
10 * @Min(value) 被注釋的元素必須是一個數字,其值必須大於等於指定的最小值
11 * @Max(value) 被注釋的元素必須是一個數字,其值必須小於等於指定的最大值
12 * @DecimalMin(value) 被注釋的元素必須是一個數字,其值必須大於等於指定的最小值
13 * @DecimalMax(value) 被注釋的元素必須是一個數字,其值必須小於等於指定的最大值
14 * @Size(max=, min=) 被注釋的元素的大小必須在指定的范圍內
15 * @Digits (integer, fraction) 被注釋的元素必須是一個數字,其值必須在可接受的范圍內
16 * @Past 被注釋的元素必須是一個過去的日期
17 * @Future 被注釋的元素必須是一個將來的日期
18 * @Pattern(regex=,flag=) 被注釋的元素必須符合指定的正則表達式
19 * Hibernate Validator 附加的 constraint
20 * @NotBlank(message =) 驗證字符串非null,且長度必須大於0
21 * @Email 被注釋的元素必須是電子郵箱地址
22 * @Length(min=,max=) 被注釋的字符串的大小必須在指定的范圍內
23 * @NotEmpty 被注釋的字符串的必須非空
24 * @Range(min=,max=,message=) 被注釋的元素必須在合適的范圍內
25 */
26 private Long id;
27
28 @Max(value=20, message="{val.age.message}")
29 private Integer age;
30
31 @NotBlank(message="{username.not.null}")
32 @Length(max=6, min=3, message="{username.length}")
33 private String username;
34
35 @NotBlank(message="{pwd.not.null}")
36 @Pattern(regexp="/^(?![0-9]+$)(?![a-zA-Z]+$)[0-9A-Za-z]{6,10}$/", message="密碼必須是6~10位數字和字母的組合")
37 private String password;
38
39
40 @Pattern(regexp="^((13[0-9])|(15[^4,\\D])|(18[0,5-9]))\\d{8}$", message="手機號格式不正確")
41 private String phone;
42
43 @Email(message="{email.format.error}")
44 private String email;
45 }
controller引用:
1 @Controller
2 @RequestMapping(value = "/val")
3 public class ValidateController {
4
5 @RequestMapping(value = "/val", method=RequestMethod.POST)
6 @ResponseBody
7 public LeeJSONResult val(@Valid @RequestBody ValBean bean, BindingResult result) throws Exception {
8
9 if(result.hasErrors()){
10 //如果沒有通過,跳轉提示
11 Map<String, String> map = getErrors(result);
12 return LeeJSONResult.error(map);
13 }else{
14 //繼續業務邏輯
15 }
16
17 return LeeJSONResult.ok();
18 }
19
20 private Map<String, String> getErrors(BindingResult result) {
21 Map<String, String> map = new HashMap<String, String>();
22 List<FieldError> list = result.getFieldErrors();
23 for (FieldError error : list) {
24 System.out.println("error.getField():" + error.getField());
25 System.out.println("error.getDefaultMessage():" + error.getDefaultMessage());
26
27 map.put(error.getField(), error.getDefaultMessage());
28 }
29 return map;
30 }
31
32 }
done