WebWork驗(yàn)證機(jī)制雜談
自Webwork2.2發(fā)布以后,Webwork驗(yàn)證機(jī)制就全部改由Ajax驗(yàn)證。驗(yàn)證的原理是一個(gè)需要驗(yàn)證的表單域在onblur時(shí)發(fā)送一次請求到服務(wù)器端進(jìn)行驗(yàn)證,然后實(shí)時(shí)提醒。
我只好手寫Javascript了。
到了Webwork2.2.2這個(gè)版本,有個(gè)好消息來了。WebWork驗(yàn)證重新支持客戶端驗(yàn)證。
客戶端驗(yàn)證的例子可見WebWork自還的例子“showcase”。使用客戶端驗(yàn)證大體上跟以前的服務(wù)器端驗(yàn)證相似,只是多了一些步驟。
完整的有以下幾個(gè)步驟:
一、編寫XXXAction-alias-validation.xml--驗(yàn)證配置文件。
文件放在需要驗(yàn)證的Action類同一目錄下,alias是可選項(xiàng),如果有幾個(gè)Action使用了同一個(gè)Action類。而你想對其中一個(gè)Action進(jìn)行驗(yàn)證,那么alias就是那個(gè)Action的名字。
如:PersonAction.java,被editPerson,savePerson,deletePerson等Action使用到,而僅需要對savePerson這個(gè)動作來驗(yàn)證時(shí),配置文件名字就是:PersonAction-savePerson-validation.xml。
Webwork支持的客戶端驗(yàn)證類型有:
◆required validator
◆requiredstring validator
◆stringlength validator
◆regex validator
◆email validator
◆url validator
◆int validator
◆double validator
二、配置Xwork.xml,保證攔截器棧里有Validation的攔截器
三、編寫Jsp(VM或FTL)。這里有幾個(gè)需要注意的地方。
1.在Jsp加上一個(gè)Head標(biāo)簽,
主要是獲取顯示錯(cuò)誤是的樣式。
2、使用
在
- 〈ww:form namespace="/foo/bar"
- action="new" validate="true"/〉
- validate="true"一句將會在客戶端生成一句:
- 〈script src="/bean/webwork/xhtml/validation.js"〉
- 〈/script〉
如果你這樣寫:
- 〈ww:form action="/foo/bar/new.action"
- validate="true"/〉
你將得不到客戶端驗(yàn)證。要注意,這個(gè)細(xì)節(jié)不容忽視。后來查文檔的時(shí)候才知道Webwork已經(jīng)提醒我們要像上一種寫法那樣寫。因?yàn)樗滥膫€(gè)名字空間下的哪個(gè)Action需要被驗(yàn)證!看吧。這是心急的錯(cuò)。不看文檔后果就自負(fù)。
以上兩種寫法,在頁面上生成Js的結(jié)果是不一樣的。
***種寫法會在頁面上生成相應(yīng)的WebWork驗(yàn)證機(jī)制規(guī)則。
第二種寫法生成的Js,只是簡單清楚報(bào)錯(cuò)信息然后提交請求到服務(wù)器,由服務(wù)器來驗(yàn)證。
只需要這三步,Webwork2.2.2的客戶端驗(yàn)證功能就算是使用了。
現(xiàn)在編輯是使用FCKEditor,另外可以看Webwork的Showcase。這東西太出彩了。
【編輯推薦】