最愛Java

          書山有路勤為徑,學(xué)海無涯苦作舟

          Struts2學(xué)習(xí)筆記——輸入校驗(一)

              Struts2提供了基于驗證框架的輸入校驗,在這種校驗方式下,所有的輸入校驗只需要通過指定的配置文件即可。Struts2中每個Action都有一個校驗文件,其規(guī)則為:<Action名字>-validation.xml。如:

          package com.struts.test.action;

          import java.util.Date;

          import com.opensymphony.xwork2.ActionSupport;

          public class RegistAction extends ActionSupport {
              
          private static final long serialVersionUID = -2113900523366315993L;
              
              
          //該請求包含的4個請求參數(shù)
              private String name;
              
          private String pass;
              
          private int age;
              
          private Date birth;
              
              
              
          public String getName() {
                  
          return name;
              }

              
          public void setName(String name) {
                  
          this.name = name;
              }

              
          public String getPass() {
                  
          return pass;
              }

              
          public void setPass(String pass) {
                  
          this.pass = pass;
              }

              
          public int getAge() {
                  
          return age;
              }

              
          public void setAge(int age) {
                  
          this.age = age;
              }

              
          public Date getBirth() {
                  
          return birth;
              }

              
          public void setBirth(Date birth) {
                  
          this.birth = birth;
              }

          }

              在類RegistAction.class相同目錄下有RegistAction-validation.xml文件:

          <?xml version="1.0" encoding="GBK"?>
          <!--指定校驗配置文件的DTD信息-->
          <!DOCTYPE validators PUBLIC 
              "-//OpenSymphone GROUP/ /XWork Validator 1.0.2/ /EN"
              "http://www.opensymphony.com/xwork/xwork-validator-1.0.2.dtd"
          >
          <!--校驗文件的根元素-->
          <validators>
              
          <!--校驗Action的name屬性-->
              
          <field name="name">
                  
          <!--指定name屬性必須滿足必填規(guī)則-->
                  
          <field-validator type="requiredstring">
                      
          <param name="trim">true</param>
                      
          <message>必須輸入名字</message>
                  
          </field-validator>
                  
          <!--指定name屬性必須匹配正則表達式-->
                  
          <field-validator type="regex">
                      
          <param name="expression"><![CDATA[(\w{4,25})]]></param>
                      
          <message>您輸入的用戶名只能是字母和數(shù)字,且長度必須在4到25之間</message>
                  
          </field-validator>
              
          </field>
              
          <!--校驗Action的pass屬性-->
              
          <field name="pass">
                  
          <!--指定pass屬性必須滿足必填規(guī)則-->
                  
          <field-validator type="requiredstring">
                      
          <param name="trim">true</param>
                      
          <message>必須輸入密碼</message>
                  
          </field-validator>
                  
          <!--指定pass屬性必須匹配正則表達式-->
                  
          <field-validator type="regex">
                      
          <param name="expression"><![CDATA[(\w{4,25})]]></param>
                      
          <message>您輸入的密碼只能是字母和數(shù)字,且長度必須在4到25之間</message>
                  
          </field-validator>
              
          </field>
              
          <!--校驗Action的age屬性-->
              
          <field name="age">
                  
          <!--指定age屬性必須在指定范圍內(nèi)-->
                  
          <field-validator type="int">
                      
          <param name="min">1</param>
                      
          <param name="max">150</param>
                      
          <message>年齡必須在1到150之間</message>
                  
          </field-validator>
              
          </field>
              
          <!--校驗Action的birth屬性-->
              
          <field name="birth">
                  
          <!--指定birth屬性必須在指定范圍內(nèi)-->
                  
          <field-validator type="date">
                      
          <param name="min">1900-01-01</param>
                      
          <param name="max">2050-02-21</param>
                      
          <message>生日必須在${min}到${max}之間</message>
                  
          </field-validator>
              
          </field>
          </validators>

              增加了這個校驗文件后,系統(tǒng)會自動加載該文件,當(dāng)用戶提交請求的時候,Struts2的校驗框架會根據(jù)該文件對用戶的請求進行校驗。當(dāng)校驗失敗后,Struts2會自動返回名為input的邏輯視圖。我們可以在視圖中添加<s:fielderror/>來查看所返回的校驗失敗信息。

              上面的校驗中,我們沒有使用國際化,如需國際化,可將message配置成<message key="name.required">這樣的形式。

              上述的校驗是在服務(wù)器端進行的,如果需要在客戶端進行校驗,可以將jsp改成struts2的標(biāo)簽格式,如:

          <html>
              
          <head/>
                  
          <!--可以導(dǎo)入一些CSS的樣式-->
              
          <s:head/>  
              
          <body>
                          
          <!--添加validate='true'來進行校驗-->
                  
          <s:form action="regist.action" validate="true">
                      
          <s:textfield label="用戶名" name="name"/>
                      
          <s:textfield label="密碼" name="pass"/>
                      
          <s:textfield label="年齡" name="age"/>
                      
          <s:textfield label="生日" name="birth"/>
                      
          <s:submit/>
                  
          </s:form>
              
          </body>
          </html>

              這里需要注意的是,國際化中需要使用<message>${getText("name.required")}</message>這樣的形式。同時,客戶端校驗僅僅支持如下校驗器:

          •     required validator(必填校驗器)
          •     requiredstring validator(必填字符串校驗器)
          •     string length validator(字符串長度校驗器)
          •     regex validator(正則表達式校驗器)
          •     email validator(郵件校驗器)
          •     url validator(網(wǎng)址校驗器)
          •     int validator(整數(shù)校驗器)
          •     double validator(雙精度數(shù)校驗器)

              Struts2提供了兩種方式來配置校驗規(guī)則:字段校驗器和非字段校驗器風(fēng)格。這兩種風(fēng)格其實并沒有本質(zhì)的不同,只是組織校驗規(guī)則的方式不同:一種是字段優(yōu)先,稱為字段校驗器風(fēng)格;另外一種是校驗器優(yōu)先,稱為非字段校驗器風(fēng)格。

              上面的例子RegistAction-validate.xml就是字段優(yōu)先校驗器風(fēng)格。如果變成非字段校驗器風(fēng)格,則如下:

          <?xml version="1.0" encoding="GBK"?>
          <!--指定校驗配置文件的DTD信息-->
          <!DOCTYPE validators PUBLIC 
              "-//OpenSymphone GROUP/ /XWork Validator 1.0.2/ /EN"
              "http://www.opensymphony.com/xwork/xwork-validator-1.0.2.dtd"
          >
          <!--校驗文件的根元素-->
          <validators>
              
          <validator type="requiredstring">
                  
          <param name="fieldName">name</param>
                  
          <param name="trim">true</param>
                  
          <message>${getText("name.requried")}</message>
              
          </validator>
              
          <validator type="regex">
                  
          <param name="fieldName">name</param>
                  
          <param name="trim">true</param>
                  
          <param name="expression"><![CDATA[(\w{4,25})]]></param>
                  
          <message>${getText("name.requried")}</message>
              
          </validator>
              
          </validators>

              上面的校驗操作并沒有使用短路操作,即當(dāng)我們使用空字符串提交頁面的時候,會發(fā)現(xiàn)error信息是:"您必須輸入用戶名! 您輸入的用戶名只能是字母和數(shù)字,且長度必須在4到25之間!"。為了達到短路效果,我們可以在<validator.../>元素或<field-validator.../>元素中增加short-curcuit="true"即可。我們在例子中將name和pass的必填校驗器配置成校驗器,那么當(dāng)必填校驗器失敗后,同一字段的其他校驗器就不會繼續(xù)校驗了。

              我們總結(jié)一下校驗順序和短路:

              校驗器的執(zhí)行順序有如下原則:

                    所有非字段風(fēng)格的校驗器優(yōu)先于字段風(fēng)格的校驗器

                    所有非字段風(fēng)格的校驗器中,排在前面的會先執(zhí)行。

                    所有字段風(fēng)格的校驗器中,排在前面的會先執(zhí)行。

              校驗器短路的原則是:

                  所有非字段校驗器是最優(yōu)先執(zhí)行,如果某個非字段校驗器校驗失敗了,則該字段上所有字段校驗器都不會獲得校驗的機會。

                  非字段校驗器的校驗失敗,不會阻止其他非字段校驗的執(zhí)行。

                  如果一個字段校驗器校驗失敗后,則該字段下的且排在該校驗失敗的校驗器之后的其他字段校驗器不會獲得校驗的機會。

                  字段校驗器永遠不會阻止非字段校驗器的執(zhí)行。

              Strut2的一個Action中可能包含多個處理邏輯,當(dāng)一個Action類包含多個類似于execute的方法時,每個方法都是一個處理邏輯。不同的處理邏輯需要不同的校驗規(guī)則,Struts2也提供了對不同Action指定不同校驗規(guī)則的的支持。

              當(dāng)需要讓一個Action可以處理多個請求時,需要配置多個邏輯的Action,如:


           

                  <action name="regist" class="com.struts.test.action.RegistAction">
                      
          <result name="input">/regist.jsp</result>
                      
          <result name="error">/error.jsp</result>
                      
          <result>/show.jsp</result>
                  
          </action>

                  
          <action name="login" class="com.struts.test.action.RegistAction" method="login">
                      
          <result name="input">/login.jsp</result>
                      
          <result name="error">/error.jsp</result>
                      
          <result>/show.jsp</result>
                  
          </action>

             

          posted on 2010-10-24 15:01 Brian 閱讀(361) 評論(0)  編輯  收藏 所屬分類: Struts2

          公告


          導(dǎo)航

          <2010年10月>
          262728293012
          3456789
          10111213141516
          17181920212223
          24252627282930
          31123456

          統(tǒng)計

          常用鏈接

          留言簿(4)

          隨筆分類

          隨筆檔案

          收藏夾

          搜索

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 荔波县| 蓬安县| 克什克腾旗| 舟山市| 鄄城县| 石楼县| 龙口市| 津市市| 丰原市| 开化县| 鄄城县| 谷城县| 乌鲁木齐县| 白沙| 五原县| 明溪县| 鹰潭市| 静安区| 西乌珠穆沁旗| 项城市| 修武县| 青阳县| 睢宁县| 治多县| 弥勒县| 三台县| 大宁县| 甘德县| 伊川县| 绿春县| 伊金霍洛旗| 金门县| 曲靖市| 朝阳市| 岳阳县| 佛坪县| 沙湾县| 桦川县| 朝阳县| 大安市| 邵东县|