• Struts2 xml表单验证


    http://jimmyfight.blog.163.com/blog/static/178439100201082025341958/

    只对action中的某个方法进行校验
    -1-
         需要校验的Action名 + -方法名 +
     -validation.xml
                                          |
                           对应xml中<action>的属性的name值

     如: RegisterAction-add-validation.xml 
           --对应 /add.action   --对RegisterAction中的add()方法进行校验

    对整个action验证就去掉方法名

    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>

    思考:可以和国际化相结合,然后注意用到正则进行验证。(OGNL表达式取值)

  • 相关阅读:
    第19章 网络通信----网络程序设计基础
    第18章 多线程----线程同步
    第18章 多线程----线程的优先级
    一款基于jquery和css3的响应式二级导航菜单
    一款纯css3实现的颜色渐变按钮
    一款基于jquery的手风琴显示详情
    推荐10款纯css3实现的实用按钮
    一款纯css3实现的数字统计游戏
    一款基于jquery ui的动画提交表单
    一款纯css实现的漂亮导航
  • 原文地址:https://www.cnblogs.com/FnuJava/p/3506333.html
Copyright © 2020-2023  润新知