• Struts2 验证框架 validation.xml 常用的验证规则


    validation.xml 的命名规则和放置路径:

    文件名:<ActionClassName>-validation.xml

    <ActionClassName>就是要验证的Action类的名字。
    要将此文件放于Class文件相同的目录。

    如果在Action类在struts配置中有多个action实例(action name),那么对应某个action的验证文件名规则如下:

    文件名:<ActionClassName>-<aliasName>-validation.xml

    例如:UserAction-login-validation.xml

    (注意:上面的<aliasName>并不是method name,而是struts.xml中配置的action的name)


    validation.xml 的内容示例:

    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE validators PUBLIC "-//OpenSymphony Group//XWork Validator 1.0.2//EN"
    "http://www.opensymphony.com/xwork/xwork-validator-1.0.2.dtd">
    <validators>

    <field name="username">

    <field-validator type="requiredstring">
    <param name="trim">true</param>
    <message>请填写用户名</message>
    </field-validator>

    <field-validator type="stringlength"> 
    <param name="minLength">4</param>
    <param name="maxLength">32</param> 
    <message>用户名长度应在4到32个字符间</message> 
    </field-validator>

    </field>



    <field name="password">

    <field-validator type="requiredstring">
    <message>请填写密码</message>
    </field-validator>

    <field-validator type="stringlength"> 
    <param name="minLength">6</param>
    <param name="maxLength">32</param> 
    <message>为了您账号的安全,请设置6个字母以上的密码(最长可设置32个字母)</message> 
    </field-validator>

    </field>
    </validators>


    Struts2 的验证规则大概有以下数种:

    required:必填校验器
    requiredstring:必填字符串校验器
    int:整数校验器
    double:双精度浮点数校验器
    date:日期校验器
    expression:表达式校验器
    fieldexpression:字段表达式校验器
    email:电子邮件校验器
    url:网址校验器
    visitor:Visitor校验器
    conversion:转换校验器
    stringlength:字符串长度校验器
    regex:正则表达式校验器


    具体的使用方法可以GOOGLE,下面举例几种常用的验证规则:

    常用的验证规则:


    1。必填检验
    <validators>

    <field name="username">
    <field-validator type="required">
      <message>指定检验失败的提示信息</message>
    </field-validator>
    </field>
    </validators>


    2。必填字符串检验
    <validators>
    <field name="username">
    <field-validator type="requiredstring">
      <param name="trim">true</param>
      <message>指定检验失败的提示信息</message>
    </field-validator>
    </field>
    </validators>


    3。整数检验器/浮点检验
    <validators>
    <field name="age">
    <field-validator type="int">
      <param name="min">1</param>
      <param name="max">150</param>
      <message>年纪必须在1到150之间</message>
    </field-validator>
       </field>
    </validators>


    4。日期检验
    <validators>
    <field name="birth">
    <field-validator type="date">
      <param name="min">1900-01-01</param>
      <param name="max">2050-02-21</param>
      <message key="birth.range"/>
    </field-validator>
    </field>
    </validators>


    5.字段表达式检验器(要求指定字段满足一个逻辑表达式)
    <validators>
    <field name="re_pass">
       <field-validator type="fieldexpression">
        <!--指定逻辑表达式 -->
            <param name="expression"> (pass eq re_pass)</param>
             <message>密码必须和确认密码相等</message>
       </field-validator>
    </field>
    </validators>


    6.邮件地址校验
    <validators>
    <field name="email">
       <field-validator type="email">
             <message>你的电子邮件地址必须是一个有效的电邮地址</message>
       </field-validator>
    </field>
    </validators>


    7。网址检验
    <validators>
    <field name="url">
       <field-validator type="url">
             <message>你的主页地址必须是一个有效的网址</message>
       </field-validator>
    </field>
    </validators>

    8.字符串长度检验
    <validators>
    <field name="user">
    <field-validator type="stringlength"> 
      <param name="minlength">4</param> 
      <param name="maxlength">20</param> 
      <message>你的用户名长度必须在4到20之间</message> 
    </field-validator> 
       </field> 
    </validators> 


    9.正则表达式检验 

    <validators> 
    <field name="user"> 
    <field-validator type="regex"> 
      <param name="expression_r"><![CDATA[(w{4,25})]]></param> 
      <message>您输入的用户名只能是字母和数组,且长度必须在4到25之间</message> 
    </field-validator> 
       </field> 
    </validators>
     
     
  • 相关阅读:
    各种推荐资料汇总。。。
    不错的blog,做计算广告学的,还有机器学习的
    大数据建模,eBay的一个牛人
    factor graph和sum product和TrueSkill相关的两个blog,相当不错
    词云制作工具。。。
    CSS:nthchild选择器用法练习
    CSS控制表格隔行变色:nthchild()选择器
    CSS3calc()函数练习(制作响应式布局)
    CSS3boxsizing属性练习(borderbox设置padding和border不会改变width和height的值)
    CSS3clippath练习
  • 原文地址:https://www.cnblogs.com/lyc-smile/p/5238129.html
Copyright © 2020-2023  润新知