Struts2 請求參數驗證

請求參數驗證

兩種方式:

手動校驗
配置校驗(xml)
1. 手動校驗(瞭解)

繼承ActionSupport,重寫validate()方法,在該方法中完成驗證,validate()方法在其他的業務方法之前執行
驗證出錯後轉向的頁面
struts.xml配置<result name="input">/validate/login.jsp</result>
什麼時候表示驗證出錯?
this.addFieldError(“a”,”錯誤信息”);方法指向的一個集合
當集合不爲空時,轉向錯誤頁面。
在jsp頁面中使用
<s:fielderror> 展示所有錯誤信息
<s:fielderror fieldName="">展示特定名稱的錯誤信息

2. 配置校驗(重點)
要求:action類必須繼承自ActionSupport
配置文件:

位置:xml文件要與action類在同一個包下
名稱:action類名-validation.xml
約束: xwork-core-2.3.7.jar 中 xwork-validator-1.0.3.dtd 下
<!DOCTYPE validators PUBLIC
"-//Apache Struts//XWork Validator 1.0.3//EN"
"http://struts.apache.org/dtds/xwork-validator-1.0.3.dtd">

寫法:

1)根元素
2)子元素,name爲頁面被驗證的表單字段的名稱
3)的子元素 這個是指定校驗器

校驗器有哪些?

在xwork-core-2.3.7.jar 中 /com/opensymphony/xwork2/validator/validators/default.xml下
  <validator name="required" class="com.opensymphony.xwork2.validator.validators.RequiredFieldValidator"/>
  <validator name="requiredstring" class="com.opensymphony.xwork2.validator.validators.RequiredStringValidator"/>
  <validator name="int" class="com.opensymphony.xwork2.validator.validators.IntRangeFieldValidator"/>
  <validator name="long" class="com.opensymphony.xwork2.validator.validators.LongRangeFieldValidator"/>
  <validator name="short" class="com.opensymphony.xwork2.validator.validators.ShortRangeFieldValidator"/>
  <validator name="double" class="com.opensymphony.xwork2.validator.validators.DoubleRangeFieldValidator"/>
  <validator name="date" class="com.opensymphony.xwork2.validator.validators.DateRangeFieldValidator"/>
  <validator name="expression" class="com.opensymphony.xwork2.validator.validators.ExpressionValidator"/>
  <validator name="fieldexpression" class="com.opensymphony.xwork2.validator.validators.FieldExpressionValidator"/>
  <validator name="email" class="com.opensymphony.xwork2.validator.validators.EmailValidator"/>
  <validator name="url" class="com.opensymphony.xwork2.validator.validators.URLValidator"/>
  <validator name="visitor" class="com.opensymphony.xwork2.validator.validators.VisitorFieldValidator"/>
  <validator name="conversion" class="com.opensymphony.xwork2.validator.validators.ConversionErrorFieldValidator"/>
  <validator name="stringlength" class="com.opensymphony.xwork2.validator.validators.StringLengthFieldValidator"/>
  <validator name="regex" class="com.opensymphony.xwork2.validator.validators.RegexFieldValidator"/>
  <validator name="conditionalvisitor" class="com.opensymphony.xwork2.validator.validators.ConditionalVisitorFieldValidator"/>

4)的子元素錯誤信息
5)子元素的值用於指定校驗器中的參數`

系統提供的校驗器:

required (必填校驗器,要求被校驗的屬性值不能爲null)
requiredstring (必填字符串校驗器,要求被校驗的屬性值不能爲null,並且長度大於0,默* 認情況下會對字符串去前後空格)
stringlength (字符串長度校驗器,要求被校驗的屬性值必須在指定的範圍內,否則校驗失敗,minLength參數指定最小長度,maxLength參數指定最大長度,trim參數指定校驗
field之前是否去除字符串前後的空格)
regex (正則表達式校驗器,檢查被校驗的屬性值是否匹配一個正則表達式,expression參數指定正則表達式,caseSensitive參數指定進行正則表達式匹配時,是否區分大小寫,默認值爲true)
int(整數校驗器,要求field的整數值必須在指定範圍內,min指定最小值,max指定最大值)
double(雙精度浮點數校驗器,要求field的雙精度浮點數必須在指定範圍內,min指定最小值,max指定最大值)
fieldexpression (字段OGNL表達式校驗器,要求field滿足一個ognl表達式,expression參數指定ognl表達式,該邏輯表達式基於ValueStack進行求值,返回true時校驗通過,否則不通過)
email(郵件地址校驗器,要求如果被校驗的屬性值非空,則必須是合法的郵件地址)
url(網址校驗器,要求如果被校驗的屬性值非空,則必須是合法的url地址)
date(日期校驗器,要求field的日期值必須在指定範圍內,min指定最小值,max指定最大值)
required 必填校驗器

<field-validator type="required">
<message>性別不能爲空!</message>
</field-validator>
requiredstring 必填字符串校驗器

<field-validator type="requiredstring">
       <param name="trim">true</param>
       <message>用戶名不能爲空!</message>
</field-validator>
stringlength:字符串長度校驗器

<field-validator type="stringlength">
    <param name="maxLength">10</param>
    <param name="minLength">2</param>
    <param name="trim">true</param>
    <message><![CDATA[產品名稱應在2-10個字符之間]]></message>
</field-validator>
int:整數校驗器

<field-validator type="int">
    <param name="min">1</param>
    <param name="max">150</param>
    <message>年齡必須在1-150之間</message>
</field-validator>
date: 日期校驗器

<field-validator type="date">
    <param name="min">1900-01-01</param>
    <param name="max">2050-02-21</param>
    <message>生日必須在${min}到${max}之間</message>
</field-validator>

url:  網絡路徑校驗器
<field-validator type="url">
    <message>傳智播客的主頁地址必須是一個有效網址</message>
</field-validator>
email:郵件地址校驗器

<field-validator type="email">
    <message>電子郵件地址無效</message>
</field-validator>
regex:正則表達式校驗器

<field-validator type="regex">
     <param name="regexExpression"><![CDATA[^13\d{9}$]]></param>
     <message>手機號格式不正確!</message>
</field-validator>
fieldexpression : 字段表達式校驗

<field-validator type="fieldexpression">
       <param name="expression"><![CDATA[(password==repassword)]]></param>
       <message>兩次密碼輸入不一致</message>
</field-validator>
對action中的指定方法進行校驗
當校驗文件的取名爲ActionClassName-validation.xml時,會對action中的所有處理方法實施輸入驗證,如果只需要對action中的某個action方法校驗,那麼,校驗文件的取名應該爲ActionClassName-ActionName-validation.xml,其中ActionName爲Struts.xml中action的名稱。例如:

<action name="user_*" class="com.java.action.UserAction" method="{1}" >
        <result name="success">/WEB-INF/page/message.jsp</result>
        <result name="input">/WEB-INF/page/addUser.jsp</result>
</action>

在UserAction中有兩個處理方法:
public String add() throws Exception{}
public String update() throws Exception{}
要對add()方法實施驗證,校驗文件取名爲:UserAction-user_add-validation.xml
要對update()方法實施驗證,校驗文件取名爲:UserAction-user_update-validation.xml

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章