美文网首页Web前端之路终端研发部
ssm中使用hibernate-validator验证BO

ssm中使用hibernate-validator验证BO

作者: 风间影月 | 来源:发表于2017-10-30 10:50 被阅读176次

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

    <!-- 国际化配置 -->    
        <bean id="localeResolver" class="org.springframework.web.servlet.i18n.CookieLocaleResolver" />
        <bean id="messageSource" class="org.springframework.context.support.ReloadableResourceBundleMessageSource">
            <property name="basenames">
                <list>
                    <value>classpath:resource/ValidationMessages</value>
                </list>
            </property>
            <property name="useCodeAsDefaultMessage" value="true" />
        </bean>
        
        
        <!-- 注册验证器 -->
        <mvc:annotation-driven validator="validator" />
        
        <bean id="validator" class="org.springframework.validation.beanvalidation.LocalValidatorFactoryBean">
            <property name="providerClass" value="org.hibernate.validator.HibernateValidator" />
            <!--这里配置将使用上面国际化配置的messageSource -->
            <property name="validationMessageSource" ref="messageSource" />
        </bean>
    

    配置错误信息:(当然也可以直接写在javabean中)

    val.age.message=\u5E74\u9F84\u4E0D\u80FD\u8D85\u8FC720\u5C81
    
    username.not.null=\u7528\u6237\u540D\u4E0D\u80FD\u4E3A\u7A7A
    pwd.not.null=\u5BC6\u7801\u4E0D\u80FD\u4E3A\u7A7A
    username.length=\u7528\u6237\u540D\u6700\u5927\u4E0D\u80FD\u8D85\u8FC7{max},\u6700\u5C0F\u4E0D\u80FD\u5C11\u4E8E{min}
    
    email.format.error=\u90AE\u7BB1\u683C\u5F0F\u4E0D\u6B63\u786E
    
    title.not.null=\u63A8\u9001\u4E3B\u9898\u4E0D\u80FD\u4E3A\u7A7A
    

    entity(setter getter 略):

    public class ValBean {
        
        
        /**
         * Bean Validation 中内置的 constraint       
         * @Null   被注释的元素必须为 null       
         * @NotNull    被注释的元素必须不为 null       
         * @AssertTrue     被注释的元素必须为 true       
         * @AssertFalse    被注释的元素必须为 false       
         * @Min(value)     被注释的元素必须是一个数字,其值必须大于等于指定的最小值       
         * @Max(value)     被注释的元素必须是一个数字,其值必须小于等于指定的最大值       
         * @DecimalMin(value)  被注释的元素必须是一个数字,其值必须大于等于指定的最小值       
         * @DecimalMax(value)  被注释的元素必须是一个数字,其值必须小于等于指定的最大值       
         * @Size(max=, min=)   被注释的元素的大小必须在指定的范围内       
         * @Digits (integer, fraction)     被注释的元素必须是一个数字,其值必须在可接受的范围内       
         * @Past   被注释的元素必须是一个过去的日期       
         * @Future     被注释的元素必须是一个将来的日期       
         * @Pattern(regex=,flag=)  被注释的元素必须符合指定的正则表达式       
         * Hibernate Validator 附加的 constraint       
         * @NotBlank(message =)   验证字符串非null,且长度必须大于0       
         * @Email  被注释的元素必须是电子邮箱地址       
         * @Length(min=,max=)  被注释的字符串的大小必须在指定的范围内       
         * @NotEmpty   被注释的字符串的必须非空       
         * @Range(min=,max=,message=)  被注释的元素必须在合适的范围内 
         */
        private Long id;
    
        @Max(value=20, message="{val.age.message}")   
        private Integer age;
        
        @NotBlank(message="{username.not.null}")
        @Length(max=6, min=3, message="{username.length}")
        private String username;
    
        @NotBlank(message="{pwd.not.null}")
        @Pattern(regexp="/^(?![0-9]+$)(?![a-zA-Z]+$)[0-9A-Za-z]{6,10}$/", message="密码必须是6~10位数字和字母的组合")
        private String password;
        
        
        @Pattern(regexp="^((13[0-9])|(15[^4,\\D])|(18[0,5-9]))\\d{8}$", message="手机号格式不正确")
        private String phone;
    
        @Email(message="{email.format.error}")
        private String email;
    }
    

    controller引用:

    @Controller
    @RequestMapping(value = "/val")
    public class ValidateController {
    
        @RequestMapping(value = "/val", method=RequestMethod.POST)
        @ResponseBody
        public LeeJSONResult val(@Valid @RequestBody ValBean bean, BindingResult result) throws Exception {
            
            if(result.hasErrors()){    
                //如果没有通过,跳转提示    
                Map<String, String> map = getErrors(result);
                return LeeJSONResult.error(map);
            }else{    
                //继续业务逻辑    
            } 
            
            return LeeJSONResult.ok();
        }
        
        private Map<String, String> getErrors(BindingResult result) {
            Map<String, String> map = new HashMap<String, String>();
            List<FieldError> list = result.getFieldErrors();
            for (FieldError error : list) {
                System.out.println("error.getField():" + error.getField());
                System.out.println("error.getDefaultMessage():" + error.getDefaultMessage());
                
                map.put(error.getField(), error.getDefaultMessage());
            }
            return map;
        }
        
    }
    

    尚自习 | 程序员的进阶平台 itzixi.com

    微信公众号:BeJavaGod

    Java技术交流群

    相关文章

      网友评论

        本文标题:ssm中使用hibernate-validator验证BO

        本文链接:https://www.haomeiwen.com/subject/xglppxtx.html