- 浏览: 93183 次
- 性别:
- 来自: 湖南
文章分类
最新评论
-
凡尘不了De:
大哥能否发一份源码,不甚感激,研究一下组卷的算法。。邮箱 lw ...
一个有点像样的考试系统 -
15959912925:
找到原因没?现在是14jar报这个错误,很无语,网上找了一堆也 ...
连接oracle数据库的一个报错 -
Mr_lee_2012:
来过。马克。
Java继承,深度理解。不上机运行你能正确写出运行结果吗? -
konnin:
打个能否给我一份源代码啊,我邮箱是pkonnin@gmail. ...
一个有点像样的考试系统 -
fy616508150:
楼主辛苦了``
Java继承,深度理解。不上机运行你能正确写出运行结果吗?
8.4 Struts2 输入校验器大全
在前几节的输入校验的配置文件中读者应该看到很多类型的 Struts2 的输入校验器。下面就对这些输入校验器做详细介绍。
技术要点
介绍 Struts2 自带的输入校验器。
演示代码
在 xwork-2.0.4.jar 包中,请读者在 \com\opensymphony\xwork2\validator\validators 路径下找一个名字为“ default.xml ”的 xml 文件。在该文件中有所有 Struts2 自带的输入校验器定义。具体代码如下:
- <!-------------文件名: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="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"/>
- </validators>
<!-------------文件名: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="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"/> </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="expression">
- <param name="expression">password==repassword</param>
- <message>两者输入不一致</message>
- </validator>
- <!-- 字段表达式校验 -->
- <!-- 非字段校验 -->
- <validator type="fieldexpression">
- <param name="expression">password==repassword</param>
- <message>两者输入不一致</message>
- </validator>
- <!-- 字段校验 -->
- <field name="field">
- <field-validator type="fieldexpression">
- <param name="expression"><![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="expression"><![CDATA[(/^13[13567890](\d{8})$/)]]></param>
- <message>手机号码必须为数字并且是11位</message>
- </validator>
- <!-- 字段校验 -->
- <field name="field">
- <field-validator type="regex">
- <param name="expression"><![CDATA[(/^13[13567890](\d{8})$/)]]></param>
- <message>手机号码必须为数字并且是11位</message>
- </field-validator>
- </field>
<!-- 必填校验 --> <!-- 非字段校验 --> <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="expression"> <param name="expression">password==repassword</param> <message>两者输入不一致</message> </validator> <!-- 字段表达式校验 --> <!-- 非字段校验 --> <validator type="fieldexpression"> <param name="expression">password==repassword</param> <message>两者输入不一致</message> </validator> <!-- 字段校验 --> <field name="field"> <field-validator type="fieldexpression"> <param name="expression"><![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="expression"><![CDATA[(/^13[13567890](\d{8})$/)]]></param> <message>手机号码必须为数字并且是11位</message> </validator> <!-- 字段校验 --> <field name="field"> <field-validator type="regex"> <param name="expression"><![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 )表达式校验器 expression 只有非字段校验格式。不能在字段校验中声明。它的属性也是 expression 。如代码所示开发者可以使用 OGNL 表达式来定义校验规则。
( 7 )字段表达式校验器 fieldexpression 判断字段是否满足一个表达式。如代码所示,当用来判断输入的密码和确认密码值是否一致就可以使用该校验器。它的属性 expression 和表达式校验器相同。不过它可以用在字段校验中。
( 8 )邮件校验器 email 来判断输入的字段是 1 个 email 时候是否符合 email 的格式。
( 9 )网址校验器 ur l 来判断输入的字段是 1 个网址时候是否符合网址的格式。
( 10 ) visitor 校验器就是判断集合类型的字段。前面章节有所介绍。这里在重申一下 context 属性是可以应用的集合类型中元素对象的别名。 appendPrefix 属性是指定在错误信息中前面是否加上特定前缀。该前缀内容可在 <message> 标签中定义。另外这两个属性也是没有声明时候,校验器不会去执行检查。
( 11 )类型转换校验器 conversion 用来判断输入字段是否进行类型转换。它有 1 个 repopulateField 属性,如果为“ true ”表明如果发生类型转换错误,返回到 struts.xml 中指定的 Action 的 input 视图界面时候还是否把原来错误的输入内容显示出来。“ false ”则相反。从这也可以看出笔者一直坚持的观点类型转换也属于输入校验的一种是有理论依据的。
( 12 )字符串长度校验器 stringlength 用于判断输入的字符串长度是否是指定的长度范围。其中 minLength 是最小字符串长度, maxLength 是最大字符串长度。 trim 属性和上述必填字符串校验器 requiredstring 中 trim 属性拥有相同功能。这三者也是属于不声明则不执行检查的可选属性。
( 13 )正则表达式校验器 regex 检查字段输入值是否和 1 个正则表达式匹配。 expression 属性中内容就是该正则表达式。还有个 caseSensitive 属性,为“ true ”则表明匹配时候对字母大小写敏感。反之则不敏感。如代码所示笔者用了 1 个判断输入的值是否是 11 位,全部由数字组成的正则表达式。对于输入手机号码数据的字段,该校验规则是最适用的。
相关推荐
### Struts2讲义知识点概览 #### 一、Struts2的历史与发展 - **Struts框架的发展历程**: - Struts最初版本发布于2000年,是Java Web开发领域的一个重要里程碑。 - 随着时间的发展和技术的进步,Struts逐渐暴露...
### Struts2框架入门知识点详解 #### 一、Struts2框架概述 ##### 1.1 Struts2简介 Struts2是一个基于MVC(Model-View-Controller)设计模式的Web应用框架,用于简化Java Web应用程序的开发过程。与传统的Java Web...
struts2讲义struts2讲义struts2讲义struts2讲义struts2讲义struts2讲义struts2讲义struts2讲义struts2讲义struts2讲义struts2讲义
本讲义将详细介绍Struts2的核心概念、工作原理以及如何在实际项目中应用。 一、Struts2简介 Struts2是Apache软件基金会的开源项目,它是Struts1的升级版,旨在解决Struts1在可扩展性和灵活性上的不足。Struts2提供...
在本讲义中,我们将深入探讨Struts2的基本概念、依赖的库、启动配置以及配置文件。 首先,开发Struts2应用需要依赖一些核心的JAR文件。这些文件包括: 1. `struts2-core-2.x.x.jar`:这是Struts2框架的核心库,...
### Struts2框架详解 #### 一、Struts2框架介绍与概述 ##### 1.1 Struts2框架概述 Struts2是一个基于MVC(Model-View-Controller)模式的开源Java Web应用框架,它提供了强大的功能来帮助开发者构建灵活、可扩展...
第2章 Web基础技术简介第3章 Struts2核心技术第4章 另一Struts2核心技术:拦截器第5章 Struts2标签库第6章 Struts2非JSP视图技术第7章 Struts2类型转换技术第8章 Struts2输入校验第9章 Struts2国际化第10章 Struts2...
本讲义详细介绍了Struts2框架的各个方面,帮助开发者从基础到进阶全面掌握其用法。 1. **Struts2概述** Struts2是Apache软件基金会的开源项目,它继承了Struts1的优点并解决了其局限性,提供了更优秀的行动控制器...
### Struts2讲义知识点概览 #### 一、Struts2的历史与发展 - **Struts框架的演变**:从Struts1到Struts2,框架经历了从MVC(Model-View-Controller)架构的经典实践到更为灵活、强大的迭代升级。 - **Struts2的...
本教程讲义深入浅出地介绍了Struts2的核心概念和技术,旨在帮助开发者快速掌握这个框架的使用。 在Struts2中,主要知识点包括: 1. **MVC设计模式**:MVC模式是软件工程中的经典设计模式,它将应用程序分为模型...
这个“struts2讲义”显然提供了一个全面的教程,旨在帮助学习者理解和掌握Struts2的核心概念和技术。以下是Struts2的一些关键知识点: 1. **MVC模式**:Struts2基于Model-View-Controller(MVC)设计模式,它将应用...
Struts2讲义 作者:吴峻申 目录 第1章 Struts过时了吗? 10 1.1 Struts历史发展过程 10 1.2 Struts2的“简历” 13 1.2.1 标签库介绍 13 1.2.2 拦截器应用目的 14 1.2.3 FilterDispatcher和Action概述 14 1.2.4 ...
Struts2讲义1 Struts2是一款基于MVC(Model-View-Controller)设计模式的Java Web开发框架,由Apache软件基金会维护。它继承了Struts1的优点,并结合了WebWork框架的功能,提供了更强大的控制层解决方案。Struts2的...
西安野马计算机培训学校的STRUTS2讲义,可能涵盖了这一框架的基础知识和高级特性,帮助学员理解和掌握Struts2的核心概念。 首先,Struts2的基础部分可能包括以下几个方面: 1. **架构原理**:讲解Struts2的MVC设计...
Struts2是Apache软件基金会...总的来说,黑暗浪子的这本Struts2讲义涵盖了Struts2的各个方面,无论对于初学者还是有经验的开发者,都是一个宝贵的参考资料,能帮助读者深入理解和熟练运用Struts2框架,提高开发效率。