表单验证:使用struts中的validator框架
第一步:
我们在struts-config.xml里:
里面必须加上validate="true"这么句代码,否则,验证机制将可能不会运行。
另外,配置文件中还须加入以下代码,表示使用插件:
注意加入<plug-in>标签的位置,该标签应该放在struts配置文件中的最后,具体位置在元素<struts-config></struts-config>内部,在<message-resources parameter="com.blog.struts.ApplicationResources" />之后,切记要注意位置,不然报错。
其次,在写法上,value的内容中/WEB-INF/validator-rules.xml是默认的,因为在项目使用struts框架时该文件已经在此目录层次下面了,那么之后的/WEB-INF/validation.xml"又是什么呢?这里需要我们手动在WEB-INF目录下新建validation.xml文件,这个文件有什么用?先看下其中写的什么。
Validation.xml:该配置文件是专供应用程序使用的,其中所描述的是特定ActionForm会用到validation-rule.xml文件中的哪些验证器。
1.<form-validation>元素
<form-validation>元素是validation.xml文件的根元素,它包含两个子元素:<global>和<formset>元素。其中<global>元素可以出现零次或多次,<formset>元素可以出现一次或多次。
2.<global>元素
<global>元素中通过<constant>子元素来定义常量表达式,每个<constant>子元素定义一个常量表达式,如果有多个常量表达式要定义则可以配置多个<constant>来实现。
3.<formset>元素
<formset>元素包括两个子元素<constant>和<form>。<constant>元素可以出现零次或多次,<form>元素可以出现一次或多次。
这里需要注意的是,在<form>标签中有包括<field>子元素。
4.<field>元素
<field>元素通过property属性指定字段的名字,通过depends属性指定具体的验证规则,验证规则来源于validation-rule.xml中所写的验证方法,这里我们要简单介绍一下validation-rule.xml里面的验证规则是默认,那如果我们有需要定义自己的验证规则也可以写在里面。<field>元素可包含的子元素为<msg>,<arg>,<var>。
第二步
把validator框架使用的消息文本添加到应用的Resource Bundle中,如在ApplicationResources.properties中加入例如:
</tr>
注意<html:errors property="password"/>之中的property对应的是form中定义的属性。
那么如果我们要创建一个在客户端进行验证的页面,我们需要如下步骤:
1.在<html:form></html:form>的外面加上<html:javascript formName="userForm"/>
2.在<html:form>中加入属性onsubmit=”return validateCardForm(this);”,即;
<html:form action="/save_user" method="post" enctype="multipart/form-data" onsubmit="return validateUserForm(this);">
3.同服务器端验证一样<td><html:password property="password" /><html:errors property="password"/></td>
重点
使用validator进行表单验证的步骤如上,其中最为关键的一步是,validation.xml文件中为表单配置验证规则的写法。
注意事项如下:
<form-validation>
<global>
在<global>中定义的常量表达式,在文件的其余地方可以直接引用。
即,这里配置的常量表达式是全局的
写法为:
<constant>
<constant-name>phone</constant-name>
<constant-value>^\(?(\d{3})\)?[-|]?(\d{8})$<constant-value>
//定义一个名为:phone的正则表达式,3位区号+8位号码
</constant>
</global>
<formset>
<form name="userForm">
<field property="userName"
//这里的property要与form表单属性名对应
depends="required,minlength,maxlength">
//这里的depends用于指定对该属性使用什么验证规则,其规则来自于validator-rule.xml文件中所写的规则。指定多个验证器时,会依次调用,直到该表单通过所有验证。
<arg0 key="userForm.userName" />
//arg0对应的是ApplicationResources.property中的{0},即:
“errors.required={0}不能为空”,其作用是将arg0中key所对应的资源文件中的“userForm.userName=用户名”的文中或者说是值替换到“errors.required={0}不能为空”中的{0},这样页面输出的是“用户名不能为空”;
下面的arg1同理{1}<arg1 name="minlength" key="${var:min}"
resource="false" />
<arg1 name="maxlength" key="${var:max}"
resource="false" />
<var>
<var-name>min</var-name>
<var-value>6</var-value>
</var>
<var>
<var-name>max</var-name>
<var-value>20</var-value>
</var>
</field>
在你写地这段代码中。那个key中所定义的变量key="${var:min}" 和<var-name>min</var-name> 中那个变量的名字可以随便写一个行吗?(key="${var:m}" 和<var-name>m</var-name> )像我括号里边写地这样行吗?我试了好几次都不行啊。还是它原来就定义好了。必须用这个名字验证才可以出来。 9 楼 grandboy 2009-02-01 这个框架当初就觉得有点复杂。后来写js做client的验证,重要逻辑自己写java来做server的验证。