`
raozhiyong11
  • 浏览: 135459 次
  • 性别: Icon_minigender_1
  • 来自: 江西
社区版块
存档分类
最新评论

Struts 结合 Validate框架验证详解

阅读更多

 

                                   Struts 结合 Validate框架验证详解

         本人初次接触Struts的验证,略知皮毛,随学笔记,与大家分享,如有错误之处请之处,多多包涵。^_^!!! 共同学习,一起进步!

QQ:317782714

E-mail:raozhiyong11@qq.com

我们按照开发步骤讲解:

1.       首先我们新建一个项目,导入Struts框架;

2.       导入Struts框架之后我们可以看到,在WEB-INF目录下有一个validator-rules.xml,这说明在导入Struts的时候validate框架也被导入进来了。validator-rules.xml  验证模板,里面定义了各种常见的验证规则,我们不需要对这个文件进行编辑,我们只需要使用模板里面定义的验证规则即可.当然我们也可以自己手写一个validator-rules.xml文件,但是必须以http://jakarta.apache.org/commons/dtds/validator_1_1_3.dtd约束它。

3.       在此基础上我们还必须自己定义一个xml文件。文件名可以任意命名,例如:validator.xm(同样他必须导入相应版本的dtd文件约束它),但是,文件必须创建在类加载器能够加载到得目录下,一般我们放在WEB-INF目录下; 这个配置文件由我们自己编辑,描述使用哪种类型的验证模板来进行验证.

4.  由于Validate框架是Struts之外的框架部分,所以我们必须在Struts中导入验证框架的插件(org.apache.struts.validator.ValidatorPlugIn);在基于以上的步骤之后,我们必须配置Struts-config.xml,加载插件和插件所学要的文件了,如下:  <plug-in className="org.apache.struts.validator.ValidatorPlugIn">

    <set-property property="pathnames" value="/WEB-INF/validator-rules.xml,/WEB-INF/validator.xml"/>

    <!-- set-property property="stopOnFirstError" value="true"/> -->

  </plug-in>

5.       接下来我们就开始做具体的验证了,我们看如下代码:

<form-validation>

<global></global>

    <formset>

<constant>

       <constant-name></constant-name>

    <constant-value></constant-value>

</constant>

    <form name="regForm">

    <!-- Validate name -->

           <field property="name" depends="required,maxlength">

              <arg0 key="name"/>

           <arg1 key="${var:maxlength}" resource="false"/>

          

           <var>

               <var-name>maxlength</var-name>

                  <var-value>20</var-value>

           </var>

           </field>

       </formset>

</form-validation>

这是我们在/WEB-INF/validator.xml中配置的一段验证用户名的简单配置信息,接下来我们看看相应的dtd文件的定义:

<!ELEMENT form-validation (global*, formset*)>     --根元素(必须有1-nglobalformset

 

<!ELEMENT formset (constant*, form+)>     --form是必须有一个的,constant可选的

<!ATTLIST formset language CDATA #IMPLIED> 

<!ATTLIST formset country CDATA #IMPLIED>

<!ATTLIST formset variant CDATA #IMPLIED>

 

<!ELEMENT form (field+)>         --field也是至少有一个

<!ATTLIST form name CDATA #REQUIRED>

 

<!ELEMENT field (msg|arg|arg0|arg1|arg2|arg3|var)*>  --field中可以有o-nmsg|arg| var

<!ATTLIST field property CDATA #REQUIRED>

<!ATTLIST field depends CDATA #IMPLIED>

<!ATTLIST field page CDATA #IMPLIED>

<!ATTLIST field indexedListProperty CDATA #IMPLIED>

 

<!ELEMENT msg EMPTY>

<!ATTLIST msg key CDATA #REQUIRED>

<!ATTLIST msg name CDATA #REQUIRED>

<!ATTLIST msg bundle CDATA #IMPLIED>

<!ATTLIST msg resource CDATA #IMPLIED>

 

<!ELEMENT arg EMPTY>

<!ATTLIST arg key CDATA #REQUIRED>

<!ATTLIST arg bundle CDATA #IMPLIED>

<!ATTLIST arg name CDATA #IMPLIED>

<!ATTLIST arg resource CDATA #IMPLIED>

<!ATTLIST arg position CDATA #IMPLIED>

…………

……

<!ELEMENT var (var-name, var-value, var-jstype?)>

<!ELEMENT var-name  (#PCDATA)>

<!ELEMENT var-value (#PCDATA)>

<!ELEMENT var-jstype (#PCDATA)>

 

这里我们就不一一讲解dtd文件了,这不是今天的重点,结合dtd和以上的xml文件可以一目了然的了解验证的结构,这里我们简单的讲述下一些元素和属性的作用:、

Global: 着这里我们可以定义formset一些公用的属性或者对象;

Formset:要验证表单的集合;

Constant:着这里我们可以定义form一些公用的属性或者对象;

Form: 相当于就是一个表单元素,他有一个name属性,如:name="regForm"

我们说这里的name的值可以不与struts-config.xmlFrom的一样,有些时候我们可以填写一个Action的路径;

Field:  表单字段

|-property="name"  该属性表示了字段的名字,和AcitionForm中的必须一致;

|-depends="required,maxlength";该属性用于指定验证的规则;

Arg:用于填充验证结果的参数;

    |-key="" ;该属性用于指向参数的值;

|-resource="" ;该属性用于控制程序是否读取配置文件;

|-name=””;该属性用于指定验证规则的名字;

Msg:用于覆盖验证规则文件中的消息信息,(自定义信息);

 

6.  既然我们是要验证表单,当然我们在struts-config.xml中的Action配置validate=”true” input=”…”是必须的。

7.  这个时候我们就需要在资源文件中配置好验证要用到的信息了;建议大家从validator-rules.xml 直接拷贝即可;

8.  我们以前在一个最普通的ActionFrom中做验证是实现它的Validate……)方法,手工写验证步骤,在我们用了validate框架之后呢? 我的From就不直接继承ActionFrom了,我们改变继承ValidatorForm,这个类里面已经为我们写好了一个验证的方法,所以我们如果在自己的Form中还保留这个方法的话就会覆盖父类中的验证方法,这对于我们来说是毫无意义的,所以我们必须在自己的Form中注释或者删除验证方法。这里需要我们注意的是:当使用的是动态From时候,我们继承是ValidatorActionForm

9.  到这里我们已经是万事俱备,只欠显示了,最后我们在页面上打入struts标签库,<bean:message ……/>可以完成我们的验证了。

10.我上述讲解的是后台验证,在struts中结合validate框架可以轻松的实现前台的JavaScript验证,从而减轻服务器的负担,因为它会自动生成JavaScript脚本,下面我们来看看前台验证的步骤:

1).前提是后台已经实现了一套validate验证;

2).jsp页面上的JavaScript区域(head之间)加上如下代码:

       <html:javascriptform Name="regForm" method="validateRegForm"/>

Name属性是Form的名称;method:生成JavaScript验证方法的名称,默认为validate+From名称;

3).在表单上添加 onSubmit 方法即可,如:onsubmit=”return validateRegForm(this)”,这里必须传入一个参数,这个参数真是我们当前的from对象。

 

--值得我们注意的是:上面只是简单的讲述validate框架在struts使用步骤,我们知道验证框架是一个非常强大的独立的验证体系,他可以应用于我们很多的应用程序,它不依赖于struts,如果想更深入如的了解这个框架,必须去看他的api和源码,在validate框架中为我们提供的验证规则也就是基本的验证,不能满足我在开发中的需求,但是框架我们提供了自定义的验证方法,只需要按照他的规则定义并且配置validator-rules.xml的相关信息即可,这里只提供思路:

一、 首先我们自定一个验证的类:CheckIdCard.java

public class CheckIdCard implements Serializable {  

public static boolean validateIdCard(Object bean,

ValidatorAction va,

                              Field field,

ActionMessages errors,

Validator validator,

                              HttpServletRequest request) {

              //此处写我们验证的逻辑。

           。。。。。。。。。。。。。。

    }

类里面定义的都是静态的方法哦。

二、配置validator-rules.xml的相关信息

    <validator name="idCard"

            classname="org.rao.struts.util.CheckIdCard "

               method=" validateIdCard "

         methodParams="java.lang.Object,

                       org.apache.commons.validator.ValidatorAction,

                       org.apache.commons.validator.Field,

                       org.apache.struts.action.ActionMessages,

                       org.apache.commons.validator.Validator,

                       javax.servlet.http.HttpServletRequest"

              depends=""

                  msg="errors.idCard"

           jsFunction="******* "/>

这就相当我们已经注册好了一个验证规则了,jsFunction="******* ":这里我们没有实现它的JavaScript验证,大家有兴趣可以自己研究。

 

 

0
0
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics