文件struts-config.xml :

<action-mappings>
  <action attribute="userloginForm" input="/login.jsp"
   name="userloginForm" parameter="method" path="/userlogin"
   scope="request" validate="true"
   type="cn.userlogin.struts.action.UserloginAction" />

 </action-mappings>
 <message-resources
  parameter="cn.userlogin.struts.ApplicationResources" />
 <plug-in className="org.apache.struts.validator.ValidatorPlugIn">
  <set-property property="pathnames" value="/WEB-INF/validator-rules.xml,/WEB-INF/validation.xml" />
 </plug-in>


1.用Javascript在客戶端進行驗證
配置:在需要驗證的JSP文件中寫入

<html:form action="/XXX" onsubmit="return validateXXXX(this);">
這里的XXX 是與要進行驗證的 forward name
validateXXXX (this);里面的XXXX是需要進行驗證的ActionForm名

<html:javascript formName="mytestForm"/>

在validation.xml文件中寫入驗證代碼就可以進行基本的驗證了。具體請參照http://www.chinajavaworld.net/forum/topic.cgi?forum=48&topic=1413&show=50

 

這種方法是在客戶端進行驗證,客戶端可以看到JAVASCRIPT部分的全代碼。安全性不高

 


2.使自己的ActionForm繼承ValidatorForm類,在里面編寫自己的方法:
public ActionErrors validate (ActionMapping mapping,HttpServletRequest request) {


        ActionErrors errors = new ActionErrors();


。。。。。。
if ( mytext.equals("aaa") ) {                    //my example
       errors.add("mytext",new ActionError("mytext.error"));
}
。。。。。。
return errors;


}
此時,如果寫了這個方法,就會屏蔽掉在Validation.xml中定義的驗證部分,換句話說就是系統運行時,Validation.xml里對應此ActionForm的定義的錯誤驗證部分不實行
如果不寫這個方法的話,系統運行時會進行Validation.xml里對應此ActionForm的定義的錯誤驗證部分的操作

此類方法是在服務器端進行驗證,驗證部分代碼客戶端不可見。

 


3.動態驗證DynaValidatorForm的使用
  不需要再寫對應的ActionForm,只需在struts-config.xml里把自己的ActionForm進行配置

    <form-bean      name="testForm"
        type="org.apache.struts.validator.DynaValidatorForm">
       <form-property name="mytext" type="java.lang.String"/>
       <form-property name="mytextarea" type="java.lang.String"/>
       <form-property name="mydatetext" type="java.lang.String"/>
    </form-bean>

在form-property里設置相應的項目,比如說mytext,mytextarea什么的,執行的時候會動態生成ActionForm

   再在validation.xml里寫入所希望的驗證代碼,就可以了


JSP文件里不需要寫入任何東西,驗證也是在服務器端進行,驗證部分代碼在JSP中不可見


 


4.組合驗證
如果使用動態驗證DynaValidatorForm的話,不許編寫自己的對應的ActionForm,相應的特殊驗證會受到相當程度的限制。


這個時候,需要將特殊驗證部分寫入對應的Action,


if(mytext.equals("aaa")){                    //My Example
ActionErrors errors = new ActionErrors();
errors.add("***",new ActionError("***.error"));      
saveErrors(request,errors);return (mapping.findForward("false"));
}