ActionSupport 实现了Validateable 和 ValidationAware 接口。由workflow 拦截器按顺序调用。
Validateable :validate()方法进行校验
ValidationAware :保存错误信息
workflow :判断是否出错(即是否含有错误信息),若果出错将页面导向input页面
在下图中,可以看出。
当页面接收到请求时,
1)会将 request params 与 请求的action中声明的属性类型进行匹配,
若类型转换失败,会使用ValidationAware将错误信息保存起来。
若匹配成功,将request params 放入valuestack中.
2)检测请求的action的方法是否需要校验。
若含有,需要判断目前请求的method是否有@SkipValidation注解,或者在struts.xml文件中的拦截器中有设置validation.excludeMethods,若有则表示需要跳过验证,若没有,则表示需要验证
需要看validateToXXXX 方法中的XXXX 与目前请求的Action Method是否相同。相同则表示需要进行验证
XXX 可以是Action的类名,可以是Field,Method
3)若校验失败,ValidationAware会将错误信息保存起来
4)workflow拦截器会检测是否含有错误信息。
含有,直接将错误信息转发到input页面
没有,显示Action对应的页面
ValidateAction.java
package com.demo.struts2.validate;
import org.apache.struts2.interceptor.validation.SkipValidation;
import com.opensymphony.xwork2.ActionSupport;
public class ValidateAction extends ActionSupport{
private static final long serialVersionUID = 1L;
private String name;
private Integer age;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
public String reg() {
System.out.println("reg");
return SUCCESS;
}
@SkipValidation
public String toRegView() {
System.out.println("toRegView");
return "regView";
}
}
struts.xml
/validate/reg.jsp
/validate/reg.jsp
reg,toRegView
reg.jsp
<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<%@taglib prefix="s" uri="/struts-tags"%>
reg.jsp
ValidateAction-validation.xml
true
请输入用户名
ValidateAction-validation.xml 的DOCTYPE 可以在 struts2-core-2.5.16.jar 下面找到 xwork-validator-1.0.3.dtd 打开这个文件如下,
ValidateAction-validation.xml 中字段验证的类型(field-validator 元素的type属性)可以在 struts2-core-2.5.16.jar里面找到 com.opensymphony.xwork2.validator.validators包里面的default.xml 如下图所示
这样做验证会出现错误
解决办法:
struts.xml 文件中必须要加上result name为input的页面,具体如下(这是由于使用验证框架后如果验证失败,workflow拦截器会导向input页面)