技术要点
介绍 Struts2 自带的输入校验器。
演示代码
在 xwork-2.0.4.jar 包中,请读者在 \com\opensymphony\xwork2\validator\validators 路径下找一个名字为“ default.xml ”的 xml 文件。在该文件中有所有 Struts2 自带的输入校验器定义。具体代码如下:
Java代码
- <!-------------文件名:default.xml-------->
- …………
- <validators>
- <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="double"
- class="com.opensymphony.xwork2.validator.validators.DoubleRangeFieldValidator"/>
- <validator name="date"
- class="com.opensymphony.xwork2.validator.validators.DateRangeFieldValidator"/>
- <validator name="expr
ession" - 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"/>
- </validators>
以上代码是所有 Struts2 输入校验器的定义,下面将这些输入校验器(一共有 13 个)的字段和非字段格式的校验形式写在如下,本例中没有程序代码示例,所有输入校验器的应用代码都是笔者自己定义的。
- <!-- 必填校验 -->
- <!-- 非字段校验 -->
- <validator type="required">
- <param name="fidleName">field</param>
- <message>请输入数据</message>
- </validator>
- <!-- 字段校验 -->
- <field name="field">
- <field-validator type="required">
- <message>请输入数据</message>
- </field-validator>
- </field>
- <!-- 必填字符串校验 -->
- <!-- 非字段校验 -->
- <validator type="requiredstring">
- <param name="fidleName">field</param>
- <param name="trim">true</param>
- <message>请输入数据</message>
- </validator>
- <!-- 字段校验 -->
- <field name="field">
- <field-validator type="requiredstring">
- <param name="trim">true</param>
- <message>请输入数据</message>
- </field-validator>
- </field>
- <!-- 整数校验 -->
- <!-- 非字段校验 -->
- <validator type="int">
- <param name="fidleName">field</param>
- <param name="min">1</param>
- <param name="max">80</param>
- <message>数字必须在${min}-${max}岁之间</message>
- </validator>
- <!-- 字段校验 -->
- <field name="field">
- <field-validator type="int">
- <param name="min">1</param>
- <param name="max">80</param>
- <message>数字必须在${min}-${max}岁之间</message>
- </field-validator>
- </field>
- <!-- 浮点校验 -->
- <!-- 非字段校验 -->
- <validator type="double">
- <param name="fidleName">field</param>
- <param name="minExclusive">0.1</param>
- <param name="maxExclusive">10.1</param>
- <message>输入浮点无效</message>
- </validator>
- <!-- 字段校验 -->
- <field name="field">
- <field-validator type="double">
- <param name="minExclusive">0.1</param>
- <param name="maxExclusive">10.1</param>
- <message>输入浮点无效</message>
- </field-validator>
- </field>
- <!-- 日期校验 -->
- <!-- 非字段校验 -->
- <validator type="date">
- <param name="fidleName">field</param>
- <param name="min">2009-01-01</param>
- <param name="max">2019-01-01</param>
- <message>日期无效</message>
- </validator>
- <!-- 字段校验 -->
- <field name="field">
- <field-validator type="date">
- <param name="min">2009-01-01</param>
- <param name="max">2019-01-01</param>
- <message>日期无效</message>
- </field-validator>
- </field>
- <!-- 表达式校验 -->
- <!-- 非字段校验 -->
- <validator type="expr
ession"> - <param name="expr
ession">password==repassword</param> - <message>两者输入不一致</message>
- </validator>
- <!-- 字段表达式校验 -->
- <!-- 非字段校验 -->
- <validator type="fieldexpression">
- <param name="expr
ession">password==repassword</param> - <message>两者输入不一致</message>
- </validator>
- <!-- 字段校验 -->
- <field name="field">
- <field-validator type="fieldexpression">
- <param name="expr
ession"><![CDATA[#password==#repassword]]></param> - <message>两者输入不一致</message>
- </field-validator>
- </field>
- <!-- 邮件校验 -->
- <!-- 非字段校验 -->
- <validator type="email">
- <param name="fidleName">field</param>
- <message>非法邮件地址</message>
- </validator>
- <!-- 字段校验 -->
- <field name="field">
- <field-validator type="email">
- <message>非法邮件地址</message>
- </field-validator>
- </field>
- <!-- 网址校验 -->
- <!-- 非字段校验 -->
- <validator type="url">
- <param name="fidleName">field</param>
- <message>无效网址</message>
- </validator>
- <!-- 字段校验 -->
- <field name="field">
- <field-validator type="url">
- <message>无效网址</message>
- </field-validator>
- </field>
- <!-- visitor校验 -->
- <!-- 非字段校验 -->
- <validator type="visitor">
- <param name="fidleName">field</param>
- <param name="context">fieldContext</param>
- <param name="appendPrefix">true</param>
- <message>输入校验</message>
- </validator>
- <!-- 字段校验 -->
- <field name="field">
- <field-validator type="visitor">
- <param name="context">fieldContext</param>
- <param name="appendPrefix">true</param>
- <message>输入校验</message>
- </field-validator>
- </field>
- <!-- 类型转换校验 -->
- <!-- 非字段校验 -->
- <validator type="conversion">
- <param name="fidleName">field</param>
- <message>类型转换错误</message>
- </validator>
- <!-- 字段校验 -->
- <field name="field">
- <field-validator type="conversion">
- <message>类型转换错误</message>
- </field-validator>
- </field>
- <!-- 字符串长度校验 -->
- <!-- 非字段校验 -->
- <validator type="stringlength">
- <param name="fidleName">field</param>
- <param name="minLength">1</param>
- <param name="maxLength">10</param>
- <param name="trim">true</param>
- <message>字符串长度必须为10位</message>
- </validator>
- <!-- 字段校验 -->
- <field name="field">
- <field-validator type="stringlength">
- <param name="minLength">1</param>
- <param name="maxLength">10</param>
- <param name="trim">true</param>
- <message>字符串长度必须为10位</message>
- </field-validator>
- </field>
- <!-- 正则表达式校验 -->
- <!-- 非字段校验 -->
- <validator type="regex">
- <param name="fidleName">field</param>
- <param name="expr
ession"><![CDATA[(/^13[13567890](\d{8})$/)]]></param> - <message>手机号码必须为数字并且是11位</message>
- </validator>
- <!-- 字段校验 -->
- <field name="field">
- <field-validator type="regex">
- <param name="expr
ession"><![CDATA[(/^13[13567890](\d{8})$/)]]></param> - <message>手机号码必须为数字并且是11位</message>
- </field-validator>
- </field>
代码解释
( 1 )必填校验器 required 是用来判断输入的字段是否为空。如果未输入任何数据则会显示错误信息。 fieldName 属性是指定校验的字段名。这个属性是所有 Struts2 自带的输入校验器都具有的属性。因此介绍其他输入校验器时,笔者略过不谈。但是读者自己要知道该属性是输入校验器共有的。该校验器其他标签都和前几章节中有过介绍,笔者也略过不谈。
( 2 )必填字符串校验器 requiredstring 用来判断输入字段是否是 1 个非空字符串 。如果不是也显示错误信息。其中的 trim 属性是在校验之前对字符串进行处理。默认是“ true ”。
( 3 )整数校验器 int 判断输入的字段数据是在一个整数范围内。 min 属性是最小值, max 是最大值。 <message> 标签内可用“ ${ 属性名 } ”格式类表示他们具体的值。
( 4 )浮点校验器 double 是 t 判断输入的字段数据是在 1 个浮点数范围内。 minInclusive 表示这个范围的最小值。 max Inclusive 表示这个范围的最大值。还有 minExclusive 和 maxExclusive 两个属性,前者表明在浮点范围之外的最小值,后者是在浮点范围之外的最大值。
注意:以上四个属性如果没有声明,则输入校验不会去检查。
( 5 )日期校验器 date 判断输入的字段的日期值是否在 1 个日期范围内。 min 是该范围的最小值, max 是最大值。他们两个属性也和浮点校验器的四个属性相同,如果没有声明则输入校验不检查。
( 6 )表达式校验器 expr
( 7 )字段表达式校验器 fieldexpression 判断字段是否满足一个表达式。如代码所示,当用来判断输入的密码和确认密码值是否一致就可以使用该校验器。它的属性 expr
( 8 )邮件校验器 email 来判断输入的字段是 1 个 email 时候是否符合 email 的格式。
( 9 )网址校验器 ur l 来判断输入的字段是 1 个网址时候是否符合网址的格式。
( 10 ) visitor 校验器就是判断集合类型的字段。前面章节有所介绍。这里在重申一下 context 属性是可以应用的集合类型中元素对象的别名。 appendPrefix 属性是指定在错误信息中前面是否加上特定前缀。该前缀内容可在 <message> 标签中定义。另外这两个属性也是没有声明时候,校验器不会去执行检查。
( 11 )类型转换校验器 conversion 用来判断输入字段是否进行类型转换。它有 1 个 repopulateField 属性,如果为“ true ”表明如果发生类型转换错误,返回到 struts.xml 中指定的 Act
( 12 )字符串长度校验器 stringlength 用于判断输入的字符串长度是否是指定的长度范围。其中 minLength 是最小字符串长度, maxLength 是最大字符串长度。 trim 属性和上述必填字符串校验器 requiredstring 中 trim 属性拥有相同功能。这三者也是属于不声明则不执行检查的可选属性。
( 13 )正则表达式校验器 regex 检查字段输入值是否和 1 个正则表达式匹配。 expr