ssm中使用hibernate-validator验证BO

简介: 目前比较流行的验证做法:前端jquery-form-validate + 后端hibernate-validate   在pom中添加相关jar: org.

目前比较流行的验证做法:前端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

 

相关文章
|
8月前
|
Java 数据库连接
后端校验(hibernate-validator)
后端校验(hibernate-validator)
201 0
|
Java 数据库连接 数据安全/隐私保护
springboot实现Validator校验
springboot实现Validator校验
50 0
|
Java 数据库连接
Java:hibernate-validator验证数据
Java:hibernate-validator验证数据
114 0
|
Java Spring
Spring data Jpa 提供的validator验证
Spring data Jpa 提供的validator验证
132 0
Spring data Jpa 提供的validator验证
|
Java 测试技术
SpringBoot 与注解 @Validated 结合对数据进行验证
SpringBoot 与注解 @Validated 结合对数据进行验证
350 0
SpringBoot 与注解 @Validated 结合对数据进行验证
|
Java 数据库连接
SpringBoot 2.0参数校验Hibernate Validator
SpringBoot 2.0参数校验Hibernate Validator
SpringBoot 2.0参数校验Hibernate Validator
Springboot使用hibernate-validator实现参数校验
Springboot使用hibernate-validator实现参数校验
266 0
Springboot使用hibernate-validator实现参数校验
|
Java 数据库连接 API
springboot使用hibernate validator校验
在做web相关的应用时,经常需要提供接口与用户交互(获取数据、上传数据等),由于这个过程需要用户进行相关的操作,为了避免出现一些错误的数据等,一般需要对数据进行校验,随着接口的增多,校验逻辑的冗余度也越来越大,虽然可以通过抽象出校验的方法来处理,但还是需要每次手动调用校验逻辑,相对来说还是不方便。
3659 0
|
Java 数据安全/隐私保护 安全
SpringBoot使用validator校验
在前台表单验证的时候,通常会校验一些数据的可行性,比如是否为空,长度,身份证,邮箱等等,那么这样是否是安全的呢,答案是否定的。因为也可以通过模拟前台请求等工具来直接提交到后台,比如postman这样的工具,那么遇到这样的问题怎么办呢,我们可以在后台也做相应的校验。
1894 0
|
Web App开发 前端开发 Java
SSM-SpringMVC-31:SpringMVC中利用hibernate-validator做后台校验
    ------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥-------------     校验有三种:前台页面校验(例如js和h5),后台校验,数据库校验 但是一般能不用数据库校验就不用数据库校验,因为性能损耗严重, 所以,我们用前台和后台俩种,可以说最好,绝大部...
2142 0