Struts 2 的 validation 验证(转)

本文详细介绍客户端和服务端的表单验证方法,包括必填项、字符串长度、正则表达式等多种验证方式,并通过实例展示了如何使用Struts2进行验证配置。
1.检验分为客户端检验和服务端检验。(两个检验都是必不可少的,客户端检验主要是过滤正常用户的误操作;而服务

端校验是整个应用阻止非法数据的最后防线)
只用一个检验文件就可以了,客户端的可以由服务端的转换而来。
检验文件的命名 <Action名字>-validation.xml
eg. RegistAction-validation.xml
<?xml version="1.0" encoding="GBK"?>
<!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="name">
<field-validator type="requiredstring"> 必填规则
<param name="trim">true</param>
<message key="name.requried" short-circuit="true"/>
</field-validator>
<field-validator type="regex"> 必须匹配正则表达式:只能是字母和数字,且长度必须在4到25

之间
<param name="expression"><![CDATA[(\w{4,25})]]></param>
<message key="name.regex"/>
用这句替换上一句,来输出国际化资源文件: <message>${getText

("name.regex")}</message>
</field-validator>
</field>
<field name="pass">
<field-validator type="requiredstring" short-circuit="true">
<param name="trim">true</param>
<message key="pass.requried"/>
</field-validator>
<field-validator type="regex">
<param name="expression"><![CDATA[(\w{4,25})]]></param>
<message key="pass.regex"/>
</field-validator>
</field>
<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>

----------------------------完
客户端检验非常简单,在表单增加validate="true"属性即可。因为服务端检验可以转换成客户端检验。
但并不是所有的服务器端检验都可以转换成客户端检验。
客户端检验仅仅支持如下几种检验器:
required ,requiredstring,stringlength,regex,email,url,int,double validator.

下面详细讲述这些检验器
1。必填检验器
<validators>
<field name="username"> 检验username属性
<field-validator type="required">
<message>指定检验失败的提示信息</message>
</field-validator>
</field>
</validators>
2。必填字符串检验器
<validators>
<field name="username"> 检验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.表达式检验器...
6.字段表达式检验器(要求指定字段满足一个逻辑表达式)
<validators>
<field name="pass">
<field-validator type="fieldexpression">
<!--指定逻辑表达式 -->
<param name="expression"> <![CDATA[(pass==rpass)]]> </param>
<message>密码必须和确认密码相等</message>
</field-validator>
</field>
</validators>
7.邮件地址校验器
<validators>
<field name="email">
<field-validator type="email">
<message>你的电子邮件地址必须是一个有效的电邮地址</message>
</field-validator>
</field>
</validators>
8。网址核验器
<validators>
<field name="url">
<field-validator type="url">
<message>你的主页地址必须是一个有效的网址</message>
</field-validator>
</field>
</validators>
9。Visitor检验器(主要用于检测Action里的复合属性,例如一个 RegistAction里包含了User类的属性,需要两个配置文件


user.java
public class User
{
User类中包含的4个基本数据类型的属性
private String name;
private String pass;
private int age;
private Date birth;
....
}


1. RegistAction-validation.xml
<?xml version="1.0" encoding="GBK"?>
<!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="user">
<field-validator type="visitor">
<param name="context">userContext</param>
<param name="appendPrefix">true</param>
<message>用户的:</message>
</field-validator>
</field>
</validators>


2. User-userContext-validation.xml(类文件的检验规则名为User-validation.xml,因为配置了 Visitor检验器时指定了

context为userContext,则该检验文件名为User-userContext-validation.xml)
<?xml version="1.0" encoding="GBK"?>

<!DOCTYPE validators PUBLIC
"-//OpenSymphony Group//XWork Validator 1.0//EN"
"http://www.opensymphony.com/xwork/xwork-validator-1.0.2.dtd">
<validators>
<field name="name">
<field-validator type="requiredstring">
<param name="trim">true</param>
<message>必须输入名字</message>
</field-validator>
<field-validator type="regex">
<param name="expression"><![CDATA[(\w{4,25})]]></param>
<message>您输入的用户名只能是字母和数组,且长度必须在4到25之间</message>
</field-validator>
</field>
<field name="pass">
<field-validator type="requiredstring">
<param name="trim">true</param>
<message>必须输入密码</message>
</field-validator>
<field-validator type="regex">
<param name="expression"><![CDATA[(\w{4,25})]]></param>
<message>您输入的密码只能是字母和数组,且长度必须在4到25之间</message>
</field-validator>
</field>
<field name="age">
<field-validator type="int">
<param name="min">1</param>
<param name="max">150</param>
<message>年纪必须在1到150之间</message>
</field-validator>
</field>
<field name="birth">
<field-validator type="date">
<param name="min">1900-01-01</param>
<param name="max">2050-02-21</param>
<message>年纪必须在${min}到${max}之间</message>
</field-validator>
</field>
</validators>
改一个jsp中的表单 <input type="text" name="user.name/user.pass/user.age/user.birth">

10.字符串长度检验器
<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>
11.正则表达式检验器

<validators>
<field name="user">
<field-validator type="regex">
<param name="expression"><![CDATA[(\w{4,25})]]></param>
<message>您输入的用户名只能是字母和数组,且长度必须在4到25之间</message>
</field-validator>
</field>
</validators>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值