输入校验

在Struts2中,可以对Action的所有方法进行校验或者对Action的指定方法进行校验。

对于输入校验Struts2提供了两种实现方法:
1、采用手工编写代码实现
2、基于xml配置方式实现


一、手工编写代码

1、实现对action中的所有方法输入校验

主要通过重写validate()方法实现,validate()方法会校验action中所有与execute方法签名相同的方法。当某个数据校验失败时,我们应该调用addFieldError()方法往系统添加校验失败信息(为了使用addFieldError()方法,actio可以继承ActionSupport),如果系统的fieldErrors包含失败星系,Struts2会将请求转发至input的result。在input的视图可以通过显示校验失败信息。

实现代码如下:
struts.xml


    
            /WEB-INF/logon.jsp
            /WEB-INF/index.jsp
    
    
    
        /WEB-INF/index.jsp
    
    

具体的Action:

public class TestVadicate extends ActionSupport {
    private static final long serialVersionUID = -2811237247567867172L;
    private String username;
    private String mobile;

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getMobile() {
        return mobile;
    }

    public void setMobile(String mobile) {
        this.mobile = mobile;
    }

    @Override
    public void validate() {
        if (username == null || "".equals(username.trim())) {
            this.addFieldError("username", "用户名不可以为空");
        }
        if (mobile == null || "".equals(mobile.trim())) {
            this.addFieldError("mobile", "手机号不可以为空");
        } else {
            if (!Pattern.compile("^1[358]\\d{9}$").matcher(this.mobile.trim()).matches()) {
                this.addFieldError("mobile", "手机号格式错误");
            }
        }
    }

    public String login() {
        
        return "success";
    }

}

两个对应的jsp:
index.jsp

姓名:
手机号:

logon.jsp:


验证成功

2、手工编写代码实现对action指定方法进行输入校验

1、通过vadicateXxx()方法实现,vadicateXxx()只会校验ation中方法名为Xxxx的方法,其中Xxxx的第一个字母要大写。当某个数据校验失败时,我们应该调用addFieldError()方法往系统的fieldError添加校验失败信息。(为了使用了addFieldError()方法,action可以继承Actionupport),如果系统的fieldErrors包含失败信息,Struts2会将请求转发到名为input的result,在input视图中可以通过显示失败信息。
例如:

public void validateLogin() {
        if (username == null || "".equals(username.trim())) {
            this.addFieldError("username", "用户名不可以为空");
        }
        if (mobile == null || "".equals(mobile.trim())) {
            this.addFieldError("mobile", "手机号不可以为空");
        } else {
            if (!Pattern.compile("^1[358]\\d{9}$").matcher(this.mobile.trim()).matches()) {
                this.addFieldError("mobile", "手机号格式错误");
            }
        }
    }

    public String login() {
        
        return "success";
    }

3、手工代码输入校验的流程

1、类型转换器对请求参数执行类型转换,并把转换后的值赋值给action中的属性。
2、如果在执行类型转换的过程中出现异常,系统会将异常信息保存的ActionContext中,conversionError拦截器会将异常信息添加到fieldErrors里。不管转换类型是否出现异常,都会进入第三步。
3、系统通过反射技术先调用action中的validateXxx()方法,Xxxx为方法名。
4、再调用action中的validate()方法。
5、经过上面4步,如果系统中的fieldErrors存在错误信息(即存在错误信息的集合的size大于0)系统自动 将请求转发至名称为input的的视图,如果系统中的fieldErrors没有任何错误信息,系统将自动执行action中的处理方法。

二、基于XML配置方式

1、实现对action的所有方法进行输入校验

使用XML配置方式实现输入校验时,Action也需要继承ActionSupport,并且提供校验文件和action类放在同一个包下,文件的取格式为:ActionClassName-validation.xml,其中该文件ActionClassName为action的简单类名,-validation.xml为固定的写法。
指定action中要校验的属性,指定校验器,上面指定的校验器requiredstring由系统提供,系统提供了满足大部分验证需求的校验器,这些校验器可以在xwork-2.xxx.jar中的com.opensymphony.xwork2.validator.validators下的default.xml中找到。
为校验失败后的提示信息,如果需要国际化,可以为message指定key属性,key的值为资源文件中的key。在这个校验文件中,对action中的字符串类型额username属性进行验证,首先要求调用trim()方法去掉空格,然后判断用户是否为空。
具体如下:


 

    
        
            true
            用户名不能为空!
        
    
    
        
            手机号不能为空!
        
        
             
             手机号格式不正确!
        
    

**注意使用xml文件进行校验时也是需要配置input视图的~

系统提供的校验器:
required(必填校验器,field的值不能为空)
requiredstring(必填字符校验器,要求field的值不能为努力,并且长度大于0,默认情况下,会对字符串去前后空格)
stringlength(字符串产股校验器,要求field的值必须在指定的范围内,否则校验校验失败,minLength参数指定最小长度,maxLength参数指定最大长度,trim参数指定校验field之前是否取出字符串前后的空格)
regex(正则表达式校验器,检查被校验的field是否匹配一个正则表达式expression参数指定正则表达式,caseSensitive参数指定正则表达式匹配是我,是否区分大小写,默认值为true)
int(整数校验器,要求field的整数值必须在指定的范围内,min指定最小值,max指定最大值)
double(双精度浮点校验器,要求field的双精度浮点数必须在指定的范围,min指定最小值,max指定最大值)
fieldexpression(字段ognl表达式校验器,要求field满足一个ognl表达式,expression参数指定ognl表达式。该逻辑表达式基于ValueStack进行求值,返回true时校验通过,否则不通过)
email(邮件地址校验器,要求如果filed的值非空,则必须是合法的邮件地址)
url(网址校验器,要求如果filed的值非空,则必须是合法的网址)
date(日期校验器,要求field的日期必须在指定范围内,min指定最小值,max指定最大值)
conversion(转换校验器,指定在类型转换失败时,提示错误信息)
visitor(用于校验action中的符合属性,它指定一个校验文件用于校验复合属性中的属性)
expression(OGNL表达式校验器,expression参数指定OGNL表达式,该逻辑表达式基于ValueStack进行求值,返回true值时校验通过,否则不通过,该校验器不可用在字段校验器风格的配置中)

2、基于xml文件配置方式对指定的action方法实现校验

当校验文件的取名为ActionClassName-validation.x
ml
时,会对action中的所有处理方法实施输入验证。如果你只需要对Action中的某一个action方法进行验证,可以改名为ActionClassName-ActionName-validation.xml
其中ActionName为struts.xml的名称。

3、基于xml文件进行校验的一些特点
当为某个action提供了ActionClassName-validation.x
ml和ActionClassName-ActionName-validation.xml两种规则的校验文件时2,系统按下面的顺序寻找校验文件:;
1、ActionClassName-validation.x
ml
2、ActionClassName-ActionName-validation.xml
系统找到第一个校验文件时还会继续搜索后面的校验文件,当搜索到所有校验文件时,会把校验文件里的所有校验规则汇总后,然后全部应用于action方法的校验。如果两个校验文件中指定的校验规则冲突时,则只使用后面文件中的校验规则。
当action继承了另外一个action,父类action的校验文件会被搜索到。

你可能感兴趣的:(输入校验)