1、對於輸入校驗struts2提供了兩種實現方法:java
一、採用手工編寫代碼實現。eclipse
(1)經過重寫validate()方法實現,validate()方法會校驗action中全部與execute方法簽名的方法。當 某個數據校驗失敗時,咱們應該調用addFieldError方法往系統的fieldErrors添加校驗失敗信息(爲了使用 addFieldError()方法,action能夠繼承ActionSupport),若是系統的fieldErrors包含失敗信 息,struts2會將請求轉發到名爲input的result。在input視圖中能夠經過<s:fielderror/>顯示失敗信息
。ui
(2)xml
經過validateXxx()方法實現,validateXxx()只會校驗action中方法名爲Xxx的方法。其中Xxx的第一個字母要大寫。 當某個數據校驗失敗時,咱們應該調用addFieldError方法往系統的fieldErrors添加校驗失敗信息(爲了使用 addFieldError()方法,action能夠繼承ActionSupport),若是系統的fieldErrors包含失敗信 息,struts2會將請求轉發到名爲input的result。在input視圖中能夠經過<s:fielderror/>顯示失敗信息
。繼承
(3)、輸入校驗的流程:ip
、類型轉換器對請求參數執行類型轉換,並把轉換後的值賦給action中的屬性。字符串
、若是在執行類型轉換的過程當中出現異常,系統會將異常信息保存到ActionContext,conversionError攔截器將異常信息封裝到fieldErrors裏。無論類型轉換是否出現異常,都會進入第3步。get
、系統經過反射技術先調用action中的validateXxx()方法,Xxx爲方法名。input
、再調用action中的validate()方法。string
、通過上面
步,若是系統中的fieldErrors存在錯誤信息(即存放錯誤信息的集合的size大於(0),系統自動將請求轉發至名稱爲input的視圖。若是系統中的fieldErrors沒有任何的錯誤信息,系統將執行action中的處理方法。
二、基於XML配置方式實現。
(1)使用基於XML配置方式實現輸入校驗時,Action也須要繼承ActionSupport,而且提供校驗文件,校驗文件和action類放在同一 個包下,文件的取名格式爲:ActionClassName-validation.xml,其中ActionClassName爲action的簡單類 名,-validation爲固定寫法。若是Action類爲cn.itcast.UserAction,那麼該文件的取名爲:UserAction- validation.xml.下面是校驗文件的模版:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE validators PUBLIC "-//OpenSymphony Group//XWork Validator 1.0.3//EN"
"http://www.opensymphony.com/xwork/xwork-validator-1.0.3.dtd">
<validators>
<field name="userNo">
<field-validator type="requiredstring">
<param name="trim"></param>
<message>用戶賬號不能爲空</message>
</field-validator>
<field-validator type="stringlength">
<param name="minLength">3</param>
<param name="maxLength">20</param>
<message>用戶賬號長度在3-20個字符之間</message>
</field-validator>
</field>
<field name="userPwd">
<field-validator type="requiredstring">
<param name="trim"></param>
<message>用戶密碼不能爲空</message>
</field-validator>
<field-validator type="stringlength">
<param name="minLength">6</param>
<param name="maxLength">50</param>
<message>用戶密碼長度在6-50個字符之間</message>
</field-validator>
</field>
<field name="userName">
<field-validator type="requiredstring">
<param name="trim"></param>
<message>用戶姓名不能爲空</message>
</field-validator>
<field-validator type="stringlength">
<param name="maxLength">50</param>
<message>用戶姓名長度不能超出50個字符</message>
</field-validator>
</field>
<field name="gender">
<field-validator type="required">
<message>性別不能爲空</message>
</field-validator>
</field>
<field name="email">
<field-validator type="email">
<message>用戶郵箱地址無效</message>
</field-validator>
</field>
</validators>
<field> 指定action中要校驗的屬性,<field-validator>指定校驗器,上面指定的校驗器requiredstring是由系統提 供的,系統提供了能知足大部分驗證需求的校驗器,這些校驗器的定義能夠是在xwork-2.x.jar中的 com.opensymphony.xwork2.validator.validators下的default.xml中找到。
<message>爲校驗失敗後的提示信息,若是字符串類型的username屬性進行驗證,首先要求調用trim()方法去掉空格,而後判斷用戶名是否爲空。
(2)在編寫ActionClassName-validation.xml校驗文件時,若是出現不了幫助信息,能夠按下面方式解決:
windwos->preferences->myeclipse->files and editors->xml->xmlcatalog點"add",在出現的窗口中的location中選"File system",而後在xwork-2.1.2解壓目錄的src\java目錄中選擇xwork-validator-1.03.dtd,回到設置窗口的時候不要急着關閉窗口,應把窗口中的Key Type該爲URL。Key改成http://www.opensympkony.com/xwodk/xwork-validator-1.0.3.dtd