struts2验证

Struts2 验证

数据 - 业务处理之前 - 合法性验证

注册表单    类型         验证规则
username - varchar2(50)  not null / 6<x<20


1.客户端验证 (js)
2.服务器端验证
  a.编码验证 (execute() / validate() / validateExecute())
    缺点:验证代码与业务代码混合在一起,不同的字段验证没有分开,不利用重用,
  b.验证框架 (ActionName-validation.xml)
 
 
<interceptor-ref name="defaultStack">
        <!-- 排除 Action中 list 方法,不需要验证 -->
        <param name="validation.excludeMethods">list</param>
        
        <!-- Action中包含 add /modify 需要验证 -->
        <!-- <param name="validation.includeMethods">add,modify</param>-->
      </interceptor-ref>



 

Struts2 验证框架 validation.xml 常用的验证规则
2009-11-04 10:51
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>%{getText("validation.username.length")}</message>
</field-validator>

<field-validator type="stringlength">  
<param name="minLength">4</param>
<param name="maxLength">32</param>  
<message>用户名长度应在${minLength}到${maxLength}个字符间</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>

<field name="rePassword">
    <field-validator type="requiredstring">
      <param name="trim">true</param>
      <message>重复密码不能为空</message>
    </field-validator>

    <field-validator type="stringlength">
      <param name="minLength">6</param>
      <param name="maxLength">8</param>
      <message>重复密码的长度需在 ${minLength} 和 ${maxLength} 之间</message>
    </field-validator>
    
    <field-validator type="fieldexpression">
      <param name="expression">rePassword eq user.password</param>
      <!--
        <param name="expression">
          <![CDATA[rePassword.equals(user.password)]]>
        </param>
      -->
      <!--
        <param name="expression">
          <![CDATA[rePassword==user.password]]>
        </param>
      -->
      <message>两次密码不一致</message>
    </field-validator>
  </field>


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>你的用户名长度必须在${minLength}到${maxlength}之间</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>
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值