对于输入校验,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 之校验器的更多相关文章

  1. struts系列:校验(二)自定义校验器

    一.自定义校验类 public class PasswordValidator extends FieldValidatorSupport { @Override public void valida ...

  2. Struts 2 数据校验要用到的类和两种校验方式以及一些校验问题的解决

    通过继承ActionSupport类来完成Action开发,ActionSupport类不仅对Action接口进行简单实现, 同时增加了验证.本地化等支持 .真实开发中自定义Action都需要继承该类 ...

  3. Struts2笔记——Action校验器

    在struts2中,我们可以实现对action的所有方法进行校验或者对action的指定方法进行校验.  对于输入校验struts2提供了两种实现方法: 1.采用手工编写代码实现. 2.基于XML配置 ...

  4. struts2校验器规范错误解决

    今天struts2的校验器的配置文件文件头出现了错误,配置如下: <!DOCTYPE validators PUBLIC        "-//OpenSymphony Group// ...

  5. 使用 Struts2 校验器校验用户注册信息

    基于验证框架的输入校验 一.创建一个struts2项目testValidators.Struts2 初体验:http://www.cnblogs.com/likailan/p/3280820.html ...

  6. 使用Struts2校验器

    今天遇到了这样的问题:我的jsp页面.web.xml.struts.xml.UserAction-validation.xml等内容写的都正确,就是无法使用校验器!在网上找了半天就是不出来,迫不得已我 ...

  7. SpringMVC【校验器、统一处理异常、RESTful、拦截器】

    前言 本博文主要讲解的知识点如下: 校验器 统一处理异常 RESTful 拦截器 Validation 在我们的Struts2中,我们是继承ActionSupport来实现校验的...它有两种方式来实 ...

  8. struts系列:校验(一)XML校验和函数方法校验

    一.jsp示例 <form action="login" method="post"> <div class="form-group ...

  9. Struts2内置校验器——完整实例代码

    一.校验器的配置风格 1.字段校验器: <field name="被校验的字段"> <field-validator type="校验器名"& ...

随机推荐

  1. [HNOI 2018]游戏

    Description 题库链接 有 \(n\) 个房间排成一列,编号为 \(1,2,...,n\) ,相邻的房间之间都有一道门.其中 \(m\) 个门上锁,其余的门都能直接打开.现在已知每把锁的钥匙 ...

  2. [HNOI2003]消防局的设立

    题目描述 2020年,人类在火星上建立了一个庞大的基地群,总共有n个基地.起初为了节约材料,人类只修建了n-1条道路来连接这些基地,并且每两个基地都能够通过道路到达,所以所有的基地形成了一个巨大的树状 ...

  3. 【bzoj4572 scoi2016】围棋

    题目描述 近日,谷歌研发的围棋AI—AlphaGo以4:1的比分战胜了曾经的世界冠军李世石,这是人工智能领域的又一里程碑. 与传统的搜索式AI不同,AlphaGo使用了最近十分流行的卷积神经网络模型. ...

  4. hdu 5532(最长上升子序列)

    Input The first line contains an integer T indicating the total number of test cases. Each test case ...

  5. 【UOJ UNR #1】火车管理

    来自FallDream的博客,未经允许,请勿转载,谢谢. 题面 考虑用可持久化线段树直接维护每个点在不同时刻,第一辆车的编号. 这样3操作就变成了区间赋值,1操作变成区间和 2操作的话,只需要查询一下 ...

  6. NFC Spy:基于Android 4.4及以上手机的非接智能卡跟踪仪

    NFC Spy 用来查看读卡器和智能卡之间的指令.数据的交互传输过程,以便 NFC/HCE 开发者分析研究底层通讯协议,定位错误指令. 本程序要使用两部带有 NFC 硬件的 Android 手机,并且 ...

  7. 笔记13 AOP中After和AfterReturning的区别

    AOP中 @Before @After @AfterThrowing@AfterReturning的执行顺序 public Object invoke(Object proxy, Method met ...

  8. DeepMoji:机器学习模型分析情绪, 情感

    DeepMoji 是一个模型,接受12亿个带有表情的推文,以了解语言如何表达情绪. 通过转移学习,该模型可以在许多情感相关的文本建模任务上获得最先进的表现. 在 http://deepmoji.mit ...

  9. RESTful 最佳实战

    在GitHub上看到一本不错的关于REST实战的书,很高兴分享阅读笔记.[下载地址] 一.什么是REST(WHAT) REST架构描述了六种约束.(统一接口.无状态.可缓存.CS架构.分层系统.按需编 ...

  10. Java 反射详解 转载

    java 反射 定义 功能 示例 概要: Java反射机制详解 | |目录 1反射机制是什么 2反射机制能做什么 3反射机制的相关API ·通过一个对象获得完整的包名和类名 ·实例化Class类对象 ...