ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Springmvc的服务端数据验证-----Hibernate Validator

2019-08-16 18:00:08  阅读:242  来源: 互联网

标签:Hibernate name 验证 Springmvc mobile Validator 注解 score public


导入Hibernate validator的Jar包

  hibernate-validator-4.3.0.Final.jar

  jboss-logging-3.1.0.CR2.jar

  validation-api-1.0.0.GA.jar

定义实体类:


public class Student {


    private String name;
    private double score;
    private String mobile;
        
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public double getScore() {
        return score;
    }
    public void setScore(double score) {
        this.score = score;
    }
    public String getMobile() {
        return mobile;
    }
    public void setMobile(String mobile) {
        this.mobile = mobile;
    }
    @Override
    public String toString() {
        return "Student [name=" + name + ", score=" + score + ", mobile="
                + mobile + "]";
    }

}

 

定义index.jsp页面  

  <body>
   Index.jsp <br>
   <form action="test/some.do" method="post">
           姓名:<input name="name"  /> ${nameMsg }<br>
           成绩:<input name="score"  /> ${scoreMsg }<br>
           手机号:<input name="mobile" />${mobileMsg }<br>
           <input type="submit" value="提交请求">
   </form>
  </body>

 

 

 

定义Controller

import java.util.List;

import org.springframework.stereotype.Controller;
import org.springframework.validation.BindingResult;
import org.springframework.validation.FieldError;
import org.springframework.validation.ObjectError;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView;

@Controller
public class MyController {

    @RequestMapping("/test/some.do")
    //@Validated 表名Student是使用了Bean验证
    //BindingResult是异常信息
    public ModelAndView doSome(@Validated Student student , BindingResult br) {
        
        ModelAndView mv = new ModelAndView();
        //默认的成功页面
        mv.setViewName("/show.jsp");

        //异常的判读处理
        List<ObjectError> errors = br.getAllErrors();
        //size() > 0 表名有异常
        if(errors.size() > 0 ){
            //获取指定属性的异常
            FieldError nameError = br.getFieldError("name");
            FieldError scoreError = br.getFieldError("score");
            FieldError mobileError = br.getFieldError("mobile");
            
            // name属性验证失败了,产生了error
            if( nameError != null){
                mv.addObject("nameMsg", nameError.getDefaultMessage());
            }
            
            if( scoreError != null){
                mv.addObject("scoreMsg", scoreError.getDefaultMessage());
            }
            
            if( mobileError != null){
                mv.addObject("mobileMsg", mobileError.getDefaultMessage());
            }
            mv.setViewName("/index.jsp");
        }
        return mv;
    }
}

/**

只要发生数据验证失败,则需要将页面重新跳转到index.jsp表单页面,让用户重写输入

BindingResult 接口中常用的方法

getAllErrors() :获取到所有的异常信息,其返回值为List ,但若没有发生异常,则该List也被创建,只不过其size()为0,而非List为Null

getFieldError() : 获取指定属性的异常信息

getErrorCount() : 获取所有异常的数量

getRawFieldValue() : 获取到用户输入引发验证异常的原始值.

*/

 

 

 

定义show.jsp页面

<html>
    <head>    
    </head>  
    <body>
       show.jsp <br>
    </body>
</html>

 

 

定义SpringMVC配置文件

  <!-- 注册包扫描器 -->
  <context:component-scan base-package="com.zx.*" />
  <!-- 注册验证器 -->
  <bean id="myValidator" class="org.springframework.validation.beanvalidation.LocalValidatorFactoryBean">
        <!-- 指定使用的验证框架, 验证器的提供者 -->
        <property name="providerClass" value="org.hibernate.validator.HibernateValidator"></property>
  </bean>
 
  <!-- 把验证器给注解驱动 -->
  <mvc:annotation-driven validator="myValidator" />
 

 

 

 

 

在实体属性上添加验证注解:

  使用的验证器注解均为:javax.validation.constraints包中的类.在注解的message属性中,可以使用{属性名}的方式来引用指定的注解的属性值

 

import javax.validation.constraints.Max;
import javax.validation.constraints.Min;
import javax.validation.constraints.Pattern;
import javax.validation.constraints.Size;

import org.hibernate.validator.constraints.NotEmpty;

public class Student {
    //验证的注解放在属性上,指定验证的规则
    @NotEmpty(message="姓名不能为空")
    @Size(min=3,max=6,message="姓名长度是{min}到{max}")
    private String name;
    @Min(value=0,message="成绩不能小于0")
    @Max(value=100,message="成绩不能大于100")
    private double score;
    @NotEmpty(message="手机号不能为空")
    @Pattern(regexp="^1[34578]\\d{9}$",message="手机号格式不正确")
    private String mobile;
        
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public double getScore() {
        return score;
    }
    public void setScore(double score) {
        this.score = score;
    }
    public String getMobile() {
        return mobile;
    }
    public void setMobile(String mobile) {
        this.mobile = mobile;
    }
    @Override
    public String toString() {
        return "Student [name=" + name + ", score=" + score + ", mobile="
                + mobile + "]";
    }

}

 

Hibernate Validator中常用的验证注解介绍:

1.@AssertFalse  : 验证注解的元素值时false

2.@AssertTrue : 验证注解的元素值时true

3.@DecimalMax(value=x) : 验证注解的元素值小于等于指定的十进制value值

4.DecimalMin(value=x) : 验证注解的元素值大于等于指定的十进制value值

5.@Degits(integer=整数位数,fraction=小数位数) : 验证注解的元素值的整数位树和小数位数上线

6.@Futrue : 验证注解的元素值(日期类型) 比当前时间晚

7.@Max(value=x) : 验证注解的元素值小于等于指定的value值

8.@Min(value=x) 验证注解的元素值大于等于指定的value值

9.@NotNull : 验证注解的元素值不是null

10.@Null : 验证注解的元素值是null

11.@Past : 验证注解的元素值(日期类型)比当前时间早

12.@Pattern(regex=正则表达式)  : 验证注解的元素值与指定的正则表达式匹配

13.@Size(min=最小值,max=最大值) : 验证注解的元素值在min和max(包含)指定区间,如字符长度,集合大小

14.@Valid : 验证关联的对象 ,如账户对象里有一个订单对象,指定验证订单对象

15.@NotEmpty : 验证注解的元素值不为null且不为空(字符长度不为0,集合大小不为0)

16.@Renge(min=最小值,max=最大值) 验证注解的元素值在最小值和最大值之间

17.@NotBlank : 验证注解的元素不为空(不为null,去除首位空格后长度为0),不同于@NotEmpty,@NotBlank只应用于字符串且在比较时会去除字符串的空格

18.@Length(min=下限,max=上线) 验证注解的元素值长度在min和max区间内

19.@Email : 验证注解的元素值时Emali,也可以通过正则表达式和flag指定自定义的email格式

注意:

  @NotNull,  @NotEmpty 和@NotBlank的区别

    @NotNull           任何对象的value不能为null

    @NotEmpty       集合对象的元素不为0,即集合不为空,也可以用于字符串不为null

    @NotBlank        只能用于字符串不为null,并且字符串trim()以后length要大于0

 

标签:Hibernate,name,验证,Springmvc,mobile,Validator,注解,score,public
来源: https://www.cnblogs.com/zwjcom/p/11365522.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有