Struts 2 之校验器
对于输入校验,Struts2提供了两种方式,1、使用validate方法;2、基于XML配置实现 。
validate()方法
支持校验的Action必须实现Validateable接口,一般直接继承ActionSupport就可以了
public void validate() { //会对所有的Action起作用 if(username == null ||"".equals(this.username.trim())){ this.addFieldError("username", "用户名不能为空"); } if(mobile == null ||"".equals(this.mobile.trim())){ this.addFieldError("mobile", "手机号不能为空"); }else{ if(!Pattern.compile("^1[3,5,8]\\d{9}$").matcher(this.mobile).matches()){ this.addFieldError("mobile","手机号格式不正确") ; } } super.validate(); }public void validateUpdate(){ //假设此Action有个名为update()的方法 //只对update()方法进行校验validateXxx,方法名第一个必须大写 if(username == null ||"".equals(this.username.trim())){ this.addFieldError("username", "用户名不能为空"); } if(mobile == null ||"".equals(this.mobile.trim())){ this.addFieldError("mobile", "手机号不能为空"); }else{ if(!Pattern.compile("^1[3,5,8]\\d{9}$").matcher(this.mobile).matches()){ this.addFieldError("mobile", "手机号格式不正确"); } } super.validate() ; }对这些错误信息,在JSP页面可以使用标签<s:fielderror/>来显示
基于XML的校验方式
基于XML方式实现校验时,Action类也需要继承ActionSupport类,并且提供校验文件,校验文件同Action类放在一个包内,文件的取名格式为:ActionClassName-validation.xml,其中ActionClassName为Action类的简单名字
<! DOCTYPE validators PUBLIC "-//OpenSymphony Group//XWorkValidator 1.0.3//EN" "http://www.opensymphony.com/xwork/xwork-validator-1.0.3.dtd"> <validators> <field name="username"> <field-validator type="requiredstring"> <param name="trim">true</param> <message>用户名不能为空</message> </field-validator> </field> <field name="mobile"> <field-validator type="requiredstring"> <param name="trim">true</param> <message>手机号不能为空</message> </field-validator> <field-validator type="regex"> <param name="expression"><![CDATA[^1[358]\d{9}$]]></param> <message>手机号格式不正确</message> </field-validator> </field> </validators>Struts 2常用内置校验器
位于xwork-2.0.4.jar压缩包中(com.opensymphony.xwork2.validator.validators)有个文件default.xml ,该文件中定义了Struts2框架内建的校验器。default.xml文件定义了常用的校验器类型。
1、类型转换检验器:
(1)非字段校验:
<validator type="conversion"> <param name="fieldName">myField</param> <message>类型转换错误</message> <param name="repopulateField">true</param> </validator>(2)字段校验:
<field name="myField"> <field-validator type="conversion"> <message>类型转换错误</message> <param name="repopulateField">true</param> </field-validator> </field>fieldName:该参数指定检查是否存在转换异常的字段名称,如果是字段校验,则不用指定该参数。
repopulateField:该参数指定当类型转换失败后,返回input页面时,类型转换失败的表单是否保留原来的错误输入。true为保留,false为不保留。
2、日期校验器:
(1)非字段校验:
<validator type="date"> <param name="fieldName">birthday</param> <param name="min">1990-01-02</param> <param name="max">2010-07-28</param> <message>生日数据错误</message> </validator>(2)字段校验:
<field name="birthday"> <field-validator type="date"> <param name="min">1990-01-01</param> <param name="max">2010-07-28</param> <message key="error.birthday"></message> </field-validator> </field>min:指定字段日期值的最小值,该参数为可选参数。
max:指定字段日期值的最大值,该参数为可选参数。
3、浮点数值校验器:
(1)非字段校验:
<validator type="double"> <param name="fieldName">percentage</param> <param name="minInclusive">20.1</param> <param name="maxInclusive">50.1</param> <message>生日数据错误</message> </validator>(2)字段校验:
<field name="percentage"> <field-validator type="double"> <param name="minInclusive">20.1</param> <param name="maxInclusive">50.1</param> <message key="error.percentage"></message> </field-validator> </field>minInclusive|minExclusive:指定字段的最小值,包含该值|不包含该值。
maxInclusive|maxExclusive:指定字段的最大值, 包含该值|不包含该值。
4、邮件地址校验器:
(1)非字段校验:
<validator type="email"> <param name="fieldName">MyEmail</param> <message>非法的邮件地址</message> </validator>(2)字段校验:
<field name="MyEmail"> <field-validator type="email"> <message>非法的邮件地址</message> </field-validator> </field>5、表达式校验器:
<validator type="expression"> <param name="expression">.......</param> <message>Failed to meet OgnlExpression...</message> </validator>expression:该参数为一个逻辑表达式,该参数使用OGNL表达式,并基于值栈计算,返回一个Boolean类型值。
6、字段表达式校验器:
(1)非字段校验:
<validator type="fieldexpression"> <param name="fieldName">myField</param> <param name="expression"><![CDATA[#myCreditLimit >#myGirfriendCreditLimit]]></param> <message>My credit limit shouldbe MORE than my girlfriend</message> </validator>(2)字段校验:
<field name="myField"> <field-validator type="fieldexpression"> <param name="expression"><![CDATA[#myCreditLimit >#myGirfriendCreditLimit]]></param> <message>My credit limitshould be MORE than my girlfriend</message> </field-validator> </field>7、整数校验器:
(1)非字段校验:
<validator type="int"> <param name="fieldName">age</param> <param name="min">10</param> <param name="max">100</param> <message>年龄必须在在${min}到${max}之间</message> </validator>(2)字段校验:
<field name="age"> <field-validator type="int"> <param name="min">10</param> <param name="max">100</param> <message>年龄必须在在${min}到${max}之间</message> </field-validator> </field><span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255);"> </span>8、正则表达式校验器:
(1)非字段校验:
<validator type="regex"> <param name="fieldName">myStrangePostcode</param> <param name="expression"><![CDATA[([aAbBcCdD][123][eEfFgG][456])]></param> </validator>(2)字段校验:
<field name="myStrangePostcode"> <field-validator type="regex"> <param name="expression"><![CDATA[#myCreditLimit >#myGirfriendCreditLimit]]></param> <message>My credit limitshould be MORE than my girlfriend</message> </field-validator> </field>expression:为必选参数,指定匹配有的表达式。
caseSensitive:指明进行匹配时,是否区分大小写,为可选参数,默认为true。
9、必填校验器:
(1)非字段校验:
<validator type="required"> <param name="fieldName">username</param> <message>用户名不能为空</message> </validator>(2)字段校验:
<field name="username"> <field-validator type="required"> <message>用户名不能为空</message> </field-validator> </field>10、必填字符串校验器:
(1)非字段校验:
<validator type="requiredstring"> <param name="fieldName">username</param> <param name="trim">true</param> <message>用户名不能为空</message> </validator>(2)字段校验:
<field name="username"> <field-validator type="requiredstring"> <param name="trim">true</param> <message>用户名不能为空</message> </field-validator> </field>trim:可选参数,用于指定是否在校验之前对字符串进行整理,默许为true。
11、字符串长度校验器:
(1)非字段校验:
<validator type="stringlength"> <param name="fieldName">username</param> <param name="minLength">4</param> <param name="maxLength">10</param> <message>用户名长度在${minLength}到${maxLength}之间</message> </validator>(2)字段校验:
<field name="username"> <field-validator type="stringlength"> <param name="minLength">4</param> <param name="maxLength">10</param> <param name="trim">true</param> <message key="error.length.username"></message> </field-validator> </field>12、网址校验器:
(1)非字段校验:
<validator type="url"> <param name="fieldName">myHomePage</param> <message>Invalid homepageurl</message> </validator>(2)字段校验:
<field name="myHomePage"> <field-validator type="url"> <message>Invalid homepageurl</message> </field-validator> </field>13、visitor校验器:
该校验器名称为:visitor,用来校验Action中定义的复合类型属性,支持简单的复合类型、数组类型、Map等集合类型。
(1)非字段校验:
<validator type="visitor"> <param name="fieldName">user</param> <param name="context">myContext</param> <param name="appendPrefix">true</param> </validator>(2)字段校验:
<field name="user"> <field-validator type="visitor"> <param name="context">myContext</param> <param name="appendPrefix">true</param> </field-validator> </field>如果想自定义一个自己的校验器,可以在Web工程的WEB-LIB\lib目录下增加一个validators.xml配置文件,在该文件中定义自己的校验器。
注意:如果使用validators.xml配置文件,则系统默认的default.xml配置文件不会加载,所以需要将default.xml的内容复制到validators.xml配置文件中。否则不能使用系统内建的校验器。
Struts 2 之校验器的更多相关文章
- struts系列:校验(二)自定义校验器
一.自定义校验类 public class PasswordValidator extends FieldValidatorSupport { @Override public void valida ...
- Struts 2 数据校验要用到的类和两种校验方式以及一些校验问题的解决
通过继承ActionSupport类来完成Action开发,ActionSupport类不仅对Action接口进行简单实现, 同时增加了验证.本地化等支持 .真实开发中自定义Action都需要继承该类 ...
- Struts2笔记——Action校验器
在struts2中,我们可以实现对action的所有方法进行校验或者对action的指定方法进行校验. 对于输入校验struts2提供了两种实现方法: 1.采用手工编写代码实现. 2.基于XML配置 ...
- struts2校验器规范错误解决
今天struts2的校验器的配置文件文件头出现了错误,配置如下: <!DOCTYPE validators PUBLIC "-//OpenSymphony Group// ...
- 使用 Struts2 校验器校验用户注册信息
基于验证框架的输入校验 一.创建一个struts2项目testValidators.Struts2 初体验:http://www.cnblogs.com/likailan/p/3280820.html ...
- 使用Struts2校验器
今天遇到了这样的问题:我的jsp页面.web.xml.struts.xml.UserAction-validation.xml等内容写的都正确,就是无法使用校验器!在网上找了半天就是不出来,迫不得已我 ...
- SpringMVC【校验器、统一处理异常、RESTful、拦截器】
前言 本博文主要讲解的知识点如下: 校验器 统一处理异常 RESTful 拦截器 Validation 在我们的Struts2中,我们是继承ActionSupport来实现校验的...它有两种方式来实 ...
- struts系列:校验(一)XML校验和函数方法校验
一.jsp示例 <form action="login" method="post"> <div class="form-group ...
- Struts2内置校验器——完整实例代码
一.校验器的配置风格 1.字段校验器: <field name="被校验的字段"> <field-validator type="校验器名"& ...
随机推荐
- [HNOI 2018]游戏
Description 题库链接 有 \(n\) 个房间排成一列,编号为 \(1,2,...,n\) ,相邻的房间之间都有一道门.其中 \(m\) 个门上锁,其余的门都能直接打开.现在已知每把锁的钥匙 ...
- [HNOI2003]消防局的设立
题目描述 2020年,人类在火星上建立了一个庞大的基地群,总共有n个基地.起初为了节约材料,人类只修建了n-1条道路来连接这些基地,并且每两个基地都能够通过道路到达,所以所有的基地形成了一个巨大的树状 ...
- 【bzoj4572 scoi2016】围棋
题目描述 近日,谷歌研发的围棋AI—AlphaGo以4:1的比分战胜了曾经的世界冠军李世石,这是人工智能领域的又一里程碑. 与传统的搜索式AI不同,AlphaGo使用了最近十分流行的卷积神经网络模型. ...
- hdu 5532(最长上升子序列)
Input The first line contains an integer T indicating the total number of test cases. Each test case ...
- 【UOJ UNR #1】火车管理
来自FallDream的博客,未经允许,请勿转载,谢谢. 题面 考虑用可持久化线段树直接维护每个点在不同时刻,第一辆车的编号. 这样3操作就变成了区间赋值,1操作变成区间和 2操作的话,只需要查询一下 ...
- NFC Spy:基于Android 4.4及以上手机的非接智能卡跟踪仪
NFC Spy 用来查看读卡器和智能卡之间的指令.数据的交互传输过程,以便 NFC/HCE 开发者分析研究底层通讯协议,定位错误指令. 本程序要使用两部带有 NFC 硬件的 Android 手机,并且 ...
- 笔记13 AOP中After和AfterReturning的区别
AOP中 @Before @After @AfterThrowing@AfterReturning的执行顺序 public Object invoke(Object proxy, Method met ...
- DeepMoji:机器学习模型分析情绪, 情感
DeepMoji 是一个模型,接受12亿个带有表情的推文,以了解语言如何表达情绪. 通过转移学习,该模型可以在许多情感相关的文本建模任务上获得最先进的表现. 在 http://deepmoji.mit ...
- RESTful 最佳实战
在GitHub上看到一本不错的关于REST实战的书,很高兴分享阅读笔记.[下载地址] 一.什么是REST(WHAT) REST架构描述了六种约束.(统一接口.无状态.可缓存.CS架构.分层系统.按需编 ...
- Java 反射详解 转载
java 反射 定义 功能 示例 概要: Java反射机制详解 | |目录 1反射机制是什么 2反射机制能做什么 3反射机制的相关API ·通过一个对象获得完整的包名和类名 ·实例化Class类对象 ...