java中用validator进行校验

1.数据校验

  对请求提交的数据进行有效性验证。

2.数据校验的分类

  客户端验证:通过javascript脚本实现

      客户端验证是不安全的。

  服务器端验证:通过java代码实现

      才是最安全的,一定要启用服务器端验证。

3.struts2如何实现服务器端验证

  1>.让action类继承ActionSupport类

  2>.重写ActionSupport的validate方法

     validate方法用于进行数据校验

     在validate方法中,如果发现不合法的数据,可以通过调用super.addFieldError将错误信息添加到验证框架中

        //用户名为空
    if(user.getUserName()==null || user.getUserName().trim().length()==0){
        super.addFieldError("userName", "用户名不能为空");
    }

      注意:validate方法总是在目标action方法调用前执行。

            如果在执行validate方法时,没有通过数据校验,那么目标action方法将不再执行。

            如果在执行validate方法时,没有通过数据校验,那么将返回结果为input。所以一定要记得添加input的result节点。

4.如何只验证Action类中的某个action方法

  在Action类中添加validateXxx()方法,这样该验证方法将只验证xxx()方法。

  如果在Action类中既添加了validate方法,也添加了validateXxx()方法,那么这两个验证方法将都起作用。并且先执行validateXxx再执行validate。

5.使用struts2服务器端数据校验在jsp页面中应该注意的事项

  1>.导入struts2的标签库

     <%@ taglib uri="/struts-tags" prefix="s" %>

  2>.使用s:fielderror标签

     :将所有验证的错误信息显示出来

     :只显示和userName相关的错误信息







实体类

 private Integer cateid;

    private Integer i;
    /**
     * This field was generated by MyBatis Generator.
     * This field corresponds to the database column category.cateName
     *
     * @mbggenerated Mon Mar 06 19:37:25 CST 2017
     */
    @NotBlank(message="商品分类名称不能为空")
    private String catename;

    /**
     * This field was generated by MyBatis Generator.
     * This field corresponds to the database column category.cateDesc
     *
     * @mbggenerated Mon Mar 06 19:37:25 CST 2017
     */
    @NotBlank(message="商品分类描述不能为空")
    private String catedesc;

    /**
     * This method was generated by MyBatis Generator.
     * This method returns the value of the database column category.cateId
     *
     * @return the value of category.cateId
     *
     * @mbggenerated Mon Mar 06 19:37:25 CST 2017
     */
    public Integer getCateid() {
        return cateid;
    }

    /**
     * This method was generated by MyBatis Generator.
     * This method sets the value of the database column category.cateId
     *
     * @param cateid the value for category.cateId
     *
     * @mbggenerated Mon Mar 06 19:37:25 CST 2017
     */
    public void setCateid(Integer cateid) {
        this.cateid = cateid;

    }


springmvc中如何使用验证框架

客户端验证(js) + 服务器端验证(java)

客户端验证能够提供更好的体验,但是不够安全。永远不要将验证寄托于客户端验证。服务器端验证才永远安全


1.springmvc 和 hibernate-validation验证框架的整合

  首先要根据spring的版本导入不同版本的hibernate-validation的jar包

  springmvc 3.x
    hibernate-validator-4.1.0.Final.jar
    validation-api-1.0.0.GA.jar
    jboss-logging-3.1.0.GA.jar

  springmvc 4.x

    classmate-1.3.1.jar
    hibernate-validator-5.3.1.Final.jar
    jboss-logging-3.3.0.Final.jar
    validation-api-1.1.0.Final.jar

2.hibernate-validation验证框架所提供的关于验证的注解

       * @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=)  被注释的元素必须在合适的范围内
       * @URL(protocol=,host,port)//检查是否是一个有效的URL,如果提供了protocol,host等,则该URL还需满足提供的条件

3.验证的使用步骤

  1>.导入验证相关的jar包

  2>.在实体类的相应属性上添加注解

        @NotBlank(message="商品名称不能为空")
    private String goodsName;
    
    @NotNull(message="商品价格不能为空")
    @DecimalMin(value="0", message="价格不能小于0")
    private Double price;
    
    @Min(value=0, message="库存数量不能小于0")
    private Integer storage;

  3>.在springmvc的控制器方法上,添加注解和参数

        @RequestMapping(value="/add", method=RequestMethod.POST)
    public String add(@Validated @ModelAttribute("goods") Goods goods, BindingResult validResult){
        
        if(validResult.hasFieldErrors()==true){
            return "goods/add";
        }
        
        
        goods.setGoodsId(generateGoodsId());
        
        goodsList.add(goods);
        return "redirect:list";
    }

        注意:BindingResult参数必须紧跟被验证的参数



你可能感兴趣的:(框架的相关配置)