使用拦截器(Interceptor)验证action请求时session是否失效。
1.首先在web.xml里配置session有效时间
<session-config>
<session-timeout>20</session-timeout>
<!-- 20:指20分钟 -->
</session-config>
2.在struts.xml里增加拦截器
<interceptors>
<!--定义新的session拦截器,名为sessionStatck-->
<!--class:拦截器内容所在的路径-->
<interceptor name="sessionStatck" class="com.common.action.CommonInterceptors"></interceptor>
<!--定义一个拦截器栈,名为myStack-->
<interceptor-stack name="myStack">
<!--拦截器栈内引用新定义的拦截器,和默认的拦截器栈-->
<interceptor-ref name="sessionStatck"></interceptor-ref>
<interceptor-ref name="defaultStack"></interceptor-ref>
</interceptor-stack>
</interceptors>
<!--设置系统默认的拦截器栈,避免每次Action时重复写入-->
<default-interceptor-ref name="myStack"></default-interceptor-ref>
3.拦截器的内容
package com.common.action;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import org.apache.struts2.ServletActionContext;
import com.user.action.UserLoginAction;
import com.util.StrUtil;
import com.opensymphony.xwork2.Action;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.AbstractInterceptor;
public class CommonInterceptors extends AbstractInterceptor{
@Override
public String intercept(ActionInvocation arg) throws Exception {
Map session=arg.getInvocationContext().getSession();
Object action=(Action)arg.getAction();
HttpServletRequest request = ServletActionContext.getRequest();
String Uri=request.getRequestURI().toString();
String usercode=StrUtil.NullProcess(session.get("usercode"));
if(action instanceof UserLoginAction||Uri.endsWith("index.action")){
return arg.invoke();
}else{
if(usercode.length()<1){ //判断session是否失效
System.out.println("no session"+usercode);
return "INPUT";
}else{
System.out.println(usercode+"----");
session.put("usercode",usercode);
return arg.invoke();
}
}
}
}
4.定义全局Result
由于拦截器可能重复使用,故将返回的result定义为一个全局变量,在struts.xml中定义
<global-results>
<result name="INPUT" type="redirect">../nosession.jsp</result>
</global-results>