struts2對action的指定方法進行校驗

在strust2中,咱們能夠實現對action的全部方法進行校驗或者對action的指定方法進行校驗。

1、對於輸入校驗struts2提供了兩種實現方法struts2對action的指定方法進行校驗java

一、採用手工編寫代碼實現struts2對action的指定方法進行校驗eclipse

(1)經過重寫validate()方法實現,validate()方法會校驗action中全部與execute方法簽名的方法。struts2對action的指定方法進行校驗當 某個數據校驗失敗時,咱們應該調用addFieldError方法往系統的fieldErrors添加校驗失敗信息(爲了使用 addFieldError()方法,action能夠繼承ActionSupport),若是系統的fieldErrors包含失敗信 息,struts2會將請求轉發到名爲input的result。在input視圖中能夠經過<s:fielderror/>顯示失敗信息struts2對action的指定方法進行校驗ui

(2)xml

經過validateXxx()方法實現,validateXxx()只會校驗action中方法名爲Xxx的方法。其中Xxx的第一個字母要大寫struts2對action的指定方法進行校驗。 當某個數據校驗失敗時,咱們應該調用addFieldError方法往系統的fieldErrors添加校驗失敗信息(爲了使用 addFieldError()方法,action能夠繼承ActionSupport),若是系統的fieldErrors包含失敗信 息,struts2會將請求轉發到名爲input的result。在input視圖中能夠經過<s:fielderror/>顯示失敗信息struts2對action的指定方法進行校驗繼承

(3)、輸入校驗的流程struts2對action的指定方法進行校驗ip

struts2對action的指定方法進行校驗、類型轉換器對請求參數執行類型轉換,並把轉換後的值賦給action中的屬性。字符串

struts2對action的指定方法進行校驗、若是在執行類型轉換的過程當中出現異常,系統會將異常信息保存到ActionContext,conversionError攔截器將異常信息封裝到fieldErrors裏。無論類型轉換是否出現異常,都會進入第3步。get

struts2對action的指定方法進行校驗、系統經過反射技術先調用action中的validateXxx()方法,Xxx爲方法名。input

struts2對action的指定方法進行校驗、再調用action中的validate()方法。string

struts2對action的指定方法進行校驗、通過上面struts2對action的指定方法進行校驗步,若是系統中的fieldErrors存在錯誤信息(即存放錯誤信息的集合的size大於(0),系統自動將請求轉發至名稱爲input的視圖。若是系統中的fieldErrors沒有任何的錯誤信息,系統將執行action中的處理方法。

二、基於XML配置方式實現struts2對action的指定方法進行校驗

(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>

struts2對action的指定方法進行校驗<field> 指定action中要校驗的屬性,<field-validator>指定校驗器,上面指定的校驗器requiredstring是由系統提 供的,系統提供了能知足大部分驗證需求的校驗器,這些校驗器的定義能夠是在xwork-2.x.jar中的 com.opensymphony.xwork2.validator.validators下的default.xml中找到。

<message>爲校驗失敗後的提示信息,若是字符串類型的username屬性進行驗證,首先要求調用trim()方法去掉空格,而後判斷用戶名是否爲空。

(2)struts2對action的指定方法進行校驗在編寫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.dtdstruts2對action的指定方法進行校驗

相關文章
相關標籤/搜索