其實可以簡單的歸納為通過XML文件來進行驗證
將你所有的驗證邏輯寫在名為validator-rules.xml的文件當中
到發(fā)帖為止,有1.0和2.0兩個版本.
看看struts的例子,下一個含有幫助文檔和和例子的struts...all.zip,解壓縮后在apps目錄里面的struts_blank你跑一下這個例子,就有關(guān)于validate的配置.
----------------------------------------------------------------
Q:如果用了validate框架,使用動態(tài)的form-bean就不會有實體form-bean存在,
那么我想在action中進行服務(wù)器驗證需要用到的例如:ForumForm forumForm = (ForumForm) form; String username = forumForm.getusername(); 那么沒有了實體form-bean我該怎樣得到username呢? 謝謝大家?guī)臀医鉀Q問題
A:那就只能通過request來得到了,不過這樣就和servlet沒什么區(qū)別了,struts的一個特點就是封裝了formbean,所以即使使用了validate驗證框架,也要在struts-config中配置form-bean,form必須繼承validateForm。
-------------------------------------------------------------------
丑陋 && Snowtears
首先,在struts-config.XML文件中要寫入:
<!-- ========== Message Resources Definitions =========================== -->
<message-resources parameter="xxx.xxxx.xxxx "/> xxx.xxxx.xxxx 的部分是資源文件的路徑
<!-- ========== Plug Ins Configuration ================================== -->
<plug-in className="org.apache.struts.validator.ValidatorPlugIn">
<set-property value="/Web-INF/validator-rules.xml,/WEB-INF/validation.xml" property="pathnames" />
</plug-in>
這里如果是想使用多個***.xml文件的話, value部分寫法如下value="/WEB-INF/validator-rules.xml,/WEB-INF/validation.xml, /WEB-INF/validation1.xml , /WEB-INF/validation2.xml "
在<action-mappings>里,定義需要驗證的畫面對應(yīng)的Action的時候要加上validate="true"
四類方法
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/
這種方法是在客戶端進行驗證,客戶端可以看到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中定義的驗證部分,換句話說就是系統(tǒng)運行時,Validation.xml里對應(yīng)此ActionForm的定義的錯誤驗證部分不實行
如果不寫這個方法的話,系統(tǒng)運行時會進行Validation.xml里對應(yīng)此ActionForm的定義的錯誤驗證部分的操作
此類方法是在服務(wù)器端進行驗證,驗證部分代碼客戶端不可見。
3.動態(tài)驗證DynaValidatorForm的使用
不需要再寫對應(yīng)的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里設(shè)置相應(yīng)的項目,比如說mytext,mytextarea什么的,執(zhí)行的時候會動態(tài)生成ActionForm
再在validation.xml里寫入所希望的驗證代碼,就可以了
JSP文件里不需要寫入任何東西,驗證也是在服務(wù)器端進行,驗證部分代碼在JSP中不可見
4.組合驗證
如果使用動態(tài)驗證DynaValidatorForm的話,不許編寫自己的對應(yīng)的ActionForm,相應(yīng)的特殊驗證會受到相當程度的限制。
這個時候,需要將特殊驗證部分寫入對應(yīng)的Action,
if(mytext.equals("aaa")){ //My Example
ActionErrors errors = new ActionErrors();
errors.add("***",new ActionError("***.error"));
saveErrors(request,errors);
return (mapping.findForward("false"));
}
就可以實現(xiàn)特殊驗證了