- 浏览: 507851 次
- 性别:
- 来自: 上海
文章分类
最新评论
-
huyuran:
...
CheckStyle使用手册 -
三剑客二无名:
楼主给力。成功完成tomcat部署打包,上来只是为了评论一下。 ...
maven自动部署war包到tomcat -
yx09167415:
盛大在为的印象中多么的伟岸。我投了几次。机会都不给。,。。。祝 ...
盛大面试经历 -
kunsyliu:
楼主给力。成功完成tomcat部署打包
maven自动部署war包到tomcat -
MrLee23:
哎,中枪了。。。
坏公司鉴别方法
8.2 利用配置文件进行输入校验方法说明
8.1 小节中说明的输入校验方法会让程序产生很多代码。如果是 1 个项目生命周期很短的项目,必然对时间的要求会很高。这时候利用 Struts2 来对该项目进行开发,开发者势必不喜欢 8.1 小节中介绍的输入校验方法。因为代码太多,工作量一下子就增大了不少。而且它是一种硬编码的形式,增大了系统各个模块之间的耦合度,也不利于项目后期的维护和实施。因此本节介绍的利用配置文件进行输入校验的方式则很好的解决了上述问题。
利用配置文件进行校验主要是增加了一些 xml 文件来对具体表单中各个字段进行输入校验。当然配置文件能做的事情不止这些。其本身的输入校验规则的书写格式也有字段和非字段两种,下面笔者就来具体介绍这些知识点。
8.2.1 Struts2 字段校验的配置文件形式
技术要点
Struts2 输入校验配置文件字段校验格式介绍。
输入校验配置文件命名方式和相关注意点。
字段校验格式和相关注意点。
演示代码
数据输入 JSP 代码:
<!---------------------文件名:register.jsp----------------> ………… <!-- 用户信息注册form表单 --> <s:form action="Register.action" validate="true"> <table width="60%" height="76" border="0"> <!-- 各标签定义 --> <s:textfield name="username" label="用户名"/> <s:password name="password" label="密 码" /> <s:password name="repassword" label="密 码确认" /> <s:textfield name="birthday" label="生日"/> <s:textfield name="mobile" label="手机号码"/> <s:textfield name="age" label="年龄"/> <s:submit value="注册" align="center"/> </table> </s:form> …………
输入校验文件代码:
<!---------文件名:RegisterAction-validation.xml----------> <?xml version="1.0" encoding="gb2312"?> <!DOCTYPE validators PUBLIC "-//OpenSymphony Group//XWork Validator 1.0.2//EN" "http://www.opensymphony.com/xwork/xwork-validator-1.0.2.dtd"> <validators> <field name="username"> <!—检验用户名的长度 -- > <field-validator type="stringlength"> <param name="minLength">6</param> <param name="maxLength">8</param> <message>用户名长度必须在${minLength}-${maxLength}位之间</message> </field-validator> <!—检验用户名是否已输入 -- > <field-validator type="requiredstring"> <message>请输入用户名</message> </field-validator> </field> <field name="password"> <!—检验密码的长度 -- > <field-validator type="stringlength"> <param name="minLength">6</param> <param name="maxLength">8</param> <message>密码长度必须在${minLength}-${maxLength}位之间</message> </field-validator> <!—检验密码是否已输入 -- > <field-validator type="requiredstring"> <message>请输入密码</message> </field-validator> </field> <field name="repassword"> <!—检验确认密码的长度 -- > <field-validator type="stringlength"> <param name="minLength">6</param> <param name="maxLength">8</param> <message>确认密码长度必须在${minLength}-${maxLength}位之间</message> </field-validator> <!—检验确认密码是否已输入 -- > <field-validator type="requiredstring"> <message>请输入确认密码</message> </field-validator> <!—检验密码和确认密码的输入内容是否一致 -- > <field-validator type="fieldexpression"> <param name="expression">password==repassword</param> <message>确认密码和密码输入不一致</message> </field-validator> </field> <field name="birthday"> <!—检验生日是否已输入 -- > <field-validator type="required"> <message>请输入生日日期</message> </field-validator> <!—检验输入日期是否在一个有效日期范围内 -- > <field-validator type="date"> <param name="min">1928-01-01</param> <param name="max">2004-01-01</param> <message>输入生日日期无效</message> </field-validator> </field> <field name="mobile"> <!—检验手机号码是否已输入 -- > <field-validator type="requiredstring"> <message>请输入手机号码</message> </field-validator> <!—检验输入手机号码长度是否是11位有效手机号码-- > <field-validator type="stringlength"> <param name="minLength">11</param> <message>请输入正确的手机号码,号码位数必须为11位</message> </field-validator> </field> <field name="age"> <!—检验年龄是否已输入 -- > <field-validator type="required"> <message>请输入年龄</message> </field-validator> <!—检验输入年龄是否符合特定年龄范围 -- > <field-validator type="int"> <param name="min">1</param> <param name="max">80</param> <message>年龄必须在${min}-${max}岁之间</message> </field-validator> </field> </validators>
代码解释
( 1 )使用配置文件来完成输入校验这种方式,首先在 Action 代码中去除所有 validate 和 validateXXX 方法的代码。然后在和 Action 类文件同一级目录下增加 XXX-validation.xml 配置文件。这里“ XXX ”是 Action 类文件名字,表示该 XML 文件中所有输入校验的规则定义和错误信息显示方式都只针对该 Action 有效。
( 2 )该输入校验的配置文件有 2 种书写格式, 1 种是本节笔者要说的字段校验格式。另 1 种是下 1 小节要介绍的非字段格式。首先来说明字段校验格式。如代码所示。在 <validators> 和 </validators> 之间使用 <field> 来对输入界面表单中每 1 个字段进行输入校验规则定义和错误信息定义。
<field> 中的 name 属性就是表单中字段名字。它里面包含 <field-validator> 标签,它的 type 属性表明是何种类型的输入校验。这些输入校验的 type 都是在 Struts2 中缺省定义的。被称之为校验器。具体这些校验器是如何形成的以及如何生效,在之后章节还有有介绍。这里读者只是知道一下就可以。
在 <field-validator> 标签内可以有 2 种标签。 1 种是 <param> 标签,该标签定义了一些输入校验规则需要用到的参数。这些参数更可以以“ ${ 参数名 } ”格式显示在视图页面上。除此之外还有 <message> 标签,该标签定义的是输入校验出错后的出错信息。这些信息是可以显示在试图界面上的。
( 3 )值得说的是代码中黑体表明的参数名字。因为 Struts2 中特定的校验类型的参数名是已经在 Struts2 代码中缺省定义过的。因此如果开发者定义的参数名字和它本身缺省定义的不符合。那么输入校验时候在配置文件中定义的该校验规则是不会生效的。比如代码中的“ stringlength ”类型校验,如果定义的最大长度不是“ maxLength ”而是其他的。则在输入数据界面,如果输入的数据超过最大长度,视图界面不会给出特定的出错信息的。
( 4 )如果在输入数据的视图界面的表单中输入上述 JSP 文件中的黑体“ validate="true" ”。则其实是另外 1 种输入校验的方式。这种方式称之为“客户端输入校验方式”。它会自动在试图页面中生成很多 JavaScript 代码。但是它是有其局限性的,因此这些代码的适合程度不是对 Struts2 中所有的主题都适合的(有关主题的基本概念翻阅“ Struts2 标签”章节)。因此笔者本身不赞同这样的输入校验方式。这里只是向读者介绍希望读者对 Struts2 的输入校验有个完整的印象。
8.2.2 Struts2 非字段校验的配置文件形式
技术要点
Struts2 输入校验配置文件非字段校验格式介绍。
非字段校验格式和相关注意点。
演示代码
于上一小节代码相比,只是输入校验配置文件中内容有所不同。代码如下:
<!--------文件名:RegisterAction-validation.xml-----------> <validators> <!—检验输入用户名长度是否在一个有效范围内 -- > <validator type="stringlength"> <param name="fieldName">username</param> <param name="minLength">6</param> <param name="maxLength">8</param> <message>用户名长度必须在${minLength}-${maxLength}位之间</message> </validator> <!—检验用户名是否已输入 -- > <validator type="requiredstring"> <param name="fieldName">username</param> <message>请输入用户名</message> </validator> <!—检验密码的长度 -- > <validator type="stringlength"> <param name="fieldName">password</param> <param name="minLength">6</param> <param name="maxLength">8</param> <message>密码长度必须在${minLength}-${maxLength}位之间</message> </validator> <!—检验密码是否已输入 -- > <validator type="requiredstring"> <param name="fieldName">password</param> <message>请输入密码</message> </validator> <!—检验确认密码的长度 -- > <validator type="stringlength"> <param name="fieldName">repassword</param> <param name="minLength">6</param> <param name="maxLength">8</param> <message>确认密码长度必须在${minLength}-${maxLength}位之间</message> </validator> <!—检验确认密码是否已输入 -- > <validator type="requiredstring"> <param name="fieldName">repassword</param> <message>请输入确认密码</message> </validator> <!—检验密码和确认密码的输入内容是否一致 -- > <validator type="fieldexpression"> <param name="fieldName">password</param> <param name="fieldName">repassword</param> <param name="expression">password==repassword</param> <message>确认密码和密码输入不一致</message> </validator> <!—检验生日是否已输入 -- > <validator type="required"> <param name="fieldName">birthday</param> <message>请输入生日日期</message> </validator> <!—检验输入日期是否在一个有效日期范围内 -- > <validator type="date"> <param name="fieldName">birthday</param> <param name="min">1928-01-01</param> <param name="max">2004-01-01</param> <message>输入生日日期无效</message> </validator> <!—检验手机号码是否已输入 -- > <validator type="requiredstring"> <param name="fieldName">mobile</param> <message>请输入手机号码</message> </validator> <!—检验输入手机号码长度是否是11位有效手机号码-- > <validator type="stringlength"> <param name="fieldName">mobile</param> <message>请输入正确的手机号码,号码位数必须为11位</message> </validator> <!—检验年龄是否已输入 -- > <validator type="required"> <param name="fieldName">age</param> <message>请输入年龄</message> </validator> <!—检验输入年龄是否符合特定年龄范围 -- > <validator type="int"> <param name="fieldName">age</param> <param name="min">1</param> <param name="max">80</param> <message>年龄必须在${min}-${max}岁之间</message> </validator> </validators>
代码解释
( 1 ) 非字段格式的输入校验方式与上 1 小节相比主要是它的书写格式不是像之前在 <validators> 和 </validators> 之间包含 <field> 标签,而是 <validator> 标签。每个 <validator> 标签定义的 type 属性还是 Struts2 自带的输入校验器的类型格式。
( 2 )在 <validator> 标签之内包含的还是 <param> 和 <message> 两种标签。但是在 <param> 中多定义了一个 fieldName 属性。这个属性定义的就是输入校验的表单字段名字。其他和之前字段格式都类似。
( 3 )由于所有数据输入的校验出错的错误信息和 8.1 节相同,因此所有的校验出错的信息显示读者可以参看图 8.1 到图 8.4 这几张图示。
8.2.3 Struts2 输入校验出错信息的国际化配置形式
技术要点
Struts2 输入校验配置文件中定义了 <message> 标签。该标签定义了很多输入校验出错信息。之前还是使用硬编码写死在配置文件中。其实可以使用 Struts2 的国际化配置将这些错误信息写在属性文件中。本小节就介绍一下如何将错误信息定义在属性文件中也为之后 Struts2 国际化章节做个基础介绍。
配置文件中修改代码介绍,介绍出错信息的 key 属性定义。
使用中文的属性文件出错信息定义代码
演示代码
配置文件代码如下:
<!------------文件名:RegisterAction-validation.xml-------------> <validators> <validator type="stringlength"> <param name="fieldName">username</param> <param name="minLength">6</param> <param name="maxLength">8</param> <message key="userNameLengthRange"></message> </validator> <validator type="requiredstring"> <param name="fieldName">username</param> <message key="userNameRequired"></message> </validator> <validator type="stringlength"> <param name="fieldName">password</param> <param name="minLength">6</param> <param name="maxLength">8</param> <message key="passwordLength"></message> </validator> <validator type="requiredstring"> <param name="fieldName">password</param> <message key="passwordRequired"></message> </validator> <validator type="stringlength"> <param name="fieldName">repassword</param> <param name="minLength">6</param> <param name="maxLength">8</param> <message key="repasswordLength"></message> </validator> <validator type="requiredstring"> <param name="fieldName">repassword</param> <message key="repasswordRequired"></message> </validator> <validator type="fieldexpression"> <param name="fieldName">password</param> <param name="fieldName">repassword</param> <param name="expression">password==repassword</param> <message key="repasswordEquals"></message> </validator> <validator type="required"> <param name="fieldName">birthday</param> <message key="birthdayRequired"></message> </validator> <validator type="date"> <param name="fieldName">birthday</param> <param name="min">1928-01-01</param> <param name="max">2004-01-01</param> <message key="birthdayRange"></message> </validator> <validator type="requiredstring"> <param name="fieldName">mobile</param> <message key="mobileRequired"></message> </validator> <validator type="stringlength"> <param name="fieldName">mobile</param> <message key="mobileLength"></message> </validator> <validator type="required"> <param name="fieldName">age</param> <message key="ageRequired"></message> </validator> <validator type="int"> <param name="fieldName">age</param> <param name="min">1</param> <param name="max">80</param> <message key="ageRange"></message> </validator> </validators>
支持中文的国际化配置属性文件代码如下:
<!---------------文件名:messageResource.properties--------------> #配置文件中<message>的key属性定义 userNameLengthRange=用户名长度必须在${minLength}-${maxLength}位之间 userNameRequired=请输入用户名 passwordLength=密码长度必须在${minLength}-${maxLength}位之间 passwordRequired=请输入密码 repasswordLength=确认密码长度必须在${minLength}-${maxLength}位之间 repasswordRequired=请输入确认密码 repasswordEquals=确认密码和密码输入不一致 birthdayRequired=请输入生日日期 birthdayRange=输入生日日期无效 mobileRequired=请输入手机号码 mobileLength=请输入正确的手机号码,号码位数必须为11位 ageRequired=请输入年龄 ageRange=年龄必须在${min}-${max}岁之间
代码解释
( 1 ) 在配置文件中笔者对 <message> 标签做了修改。使用了 key 属性,这些 key 属性定义的内容都是一个个出错信息名字。而这些名字是在国际化配置的属性文件中定义的。这里笔者使用了非字段定义的格式来写配置文件中的代码。其实字段格式也是相同,都是修改 <message> 标签中的内容。
( 2 )在支持中文的国际化配置属性文件“ messageResource.properties ”中,笔者对所有 keu 属性定义的出错信息名字做了一一具体相关的出错信息定义。因为该文件是中文国际化的属性文件,因此都是中文的出错信息。
( 3 )有关 Struts2 国际化的配置在后面章节会具体完整的介绍,这里只是让读者知道输入校验的出错信息都是可以国际化的赋予各个语言版本。
- 8.2代码.rar (9.6 MB)
- 下载次数: 849
评论
你应该听说过sql注入和恶意脚本侵入吧?我以前的观点和你相同,后来做了几个互联网项目发觉不对。之所以会产生你这样的观点,因为我之前也是一直做企业级应用的BS系统,没有做过互联网BS系统。我想你大概和我以前情况相同,没有做过互联网BS系统导致
一般情况下是前台js验证,楼主写的是后台验证(增加了安全性)
因为有的人可以绕过前台验证,直接进后台,这时后台验证就起到作用了,估计很少有后台验证的吧?
位置可以随便放吗?
有没有哪里指定该文件的?谢谢了~~
发表评论
-
struts2讲义每章节代码包汇总
2009-11-12 20:57 8305不知道javaeye一个blog允许上传多大的附件。 先试试 ... -
放出完整的Struts2讲义
2009-11-06 08:17 15333谢谢各位长期以来的支持~ -
Struts2讲义46
2009-11-05 08:46 255910.2.2 <decorator:use ... -
Struts2讲义45
2009-11-04 09:40 183410.2 sitemesh 高级应用 在 ... -
Struts2讲义44
2009-11-03 08:26 1856第10 章 Struts2 页面布局实现 ... -
Struts2讲义43
2009-11-02 13:21 23229.3 用户主动选择国 ... -
Struts2讲义42
2009-11-01 02:05 15779.2.3 Struts2 临时范围属性文件国 ... -
Struts2讲义41
2009-10-31 11:36 15069.2.2 Struts2Action 范围属 ... -
Struts2讲义40
2009-10-30 00:16 16279.2 Struts2 国际化使用范围说明 ... -
Struts2讲义39
2009-10-29 10:44 17919.1.2 占位符国际化使用 ... -
Struts2讲义38
2009-10-28 08:56 2130第9 章 Struts2 国际化 在第 ... -
Struts2讲义37
2009-10-27 15:23 18708.4 Struts2 输入校验器大全 在 ... -
Struts2讲义36
2009-10-26 11:15 16268.3 集合类型输入校验介绍 于之前类 ... -
Struts2讲义34
2009-10-24 01:47 1827第8 章 Struts2 输入校验 ... -
Struts2讲义33
2009-10-23 08:37 16397.2 类型转换发生异常处理方案 类型 ... -
Struts2讲义32
2009-10-22 13:19 19617.1.3 Set 集合类型数据类型转换功能 ... -
Struts2讲义31
2009-10-21 08:14 18187.1.2 List 集合类型数据类型转换功能 ... -
Struts2讲义30
2009-10-20 09:11 1793第7 章 Struts2 类型转换技术 ... -
Struts2讲义29
2009-10-19 08:33 18466.3 JasperReports 报表视图技术使 ... -
Struts2讲义28
2009-10-17 12:23 18406.2 freemarker 视图技术使用介绍 ...
相关推荐
### 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 Struts2是一款基于MVC(Model-View-Controller)设计模式的Java Web开发框架,由Apache软件基金会维护。它继承了Struts1的优点,并结合了WebWork框架的功能,提供了更强大的控制层解决方案。Struts2的...
西安野马计算机培训学校的STRUTS2讲义,可能涵盖了这一框架的基础知识和高级特性,帮助学员理解和掌握Struts2的核心概念。 首先,Struts2的基础部分可能包括以下几个方面: 1. **架构原理**:讲解Struts2的MVC设计...
Struts2是Apache软件基金会...总的来说,黑暗浪子的这本Struts2讲义涵盖了Struts2的各个方面,无论对于初学者还是有经验的开发者,都是一个宝贵的参考资料,能帮助读者深入理解和熟练运用Struts2框架,提高开发效率。
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 ...