struts2 之配置拦截器使网站页面在session失效后退回到登录页面

要实现这个功能主要实现以下:

1、将session的失效时间设置为10分钟。
2、编写拦截器判断session是否失效
3、如果失效,则返回登录。


1、首先在web.xml中配置session的有效时间:

<session-config>
  <!--  session-timeout元素用来指定默认的会话超时时间间隔,以分钟为单位。该元素值必须为整数。如果session-timeout元素的值为零或负数,则表示会话将永远不会超时。 -->
    <session-timeout>10</session-timeout>
 </session-config>

2、编写拦截器判断session是否失效:

package com.xmsjhs.www.struts.interceptor;
import java.util.Map;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.AbstractInterceptor;
import com.xmsjhs.www.vo.LoginInfo;
/**
 * 通过struts2拦截器验证用户登录没有
 * @author Administrator
 *
 */
@SuppressWarnings("serial")
public class LoginInterceptor extends AbstractInterceptor{
@Override
public String intercept(ActionInvocation ai) throws Exception {
if(null==ai){
return null;
}
Map<?, ?> session=ai.getInvocationContext().getSession();
LoginInfo loginInfo=(LoginInfo)session.get("loginInfo");//loginInfo为设置的session对象
if(null!=loginInfo){
System.out.println("session处在有效期间");
return ai.invoke();//已登录时正常执行
}else{
System.out.println("session失效");
return "login";//没有登录时转到登录页
}
}
}

3然后在struts.xml中给每个action配置拦截器,并声明一个全局的<global-results>,当session失效的时候拦截器会转发到login.jsp

<package name="mydefault" extends="struts-default">
<!-- 定义拦截器 -->
<interceptors>
<interceptor name="checkLogin" class="loginInterceptor" />
<interceptor-stack name="myDefaultStack">
<interceptor-ref name="checkLogin" />
<interceptor-ref name="defaultStack" />
</interceptor-stack>
</interceptors>

<global-results>
<result name="login">/login.jsp</result>
</global-results>
</package>

在每个action中配置拦截器

<interceptor-ref name="myDefaultStack"></interceptor-ref>

4、如果要想使退出的页面跳出iframe框架,则可以用JavaScript方法解决:

在页面的javascript代码处添加如下可解决问题:

if (window != top)
    top.location.href = location.href;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值