`

session超时跳出iframe并跳到登陆页面

阅读更多

    在网页编程时,我们经常需要处理,当session过期时,我们要跳到登陆页面让用户登陆,由于我们可能用到IFrame框架,所以我们我登陆页面需要显示在整个页面,而不是一个IFrame中,大部分的网友是用下面的代码进行实现的。

 

    在过滤器中写如下代码:

printWriter out = response.getWriter();
out.write("<script>window.parent.location.href='login.jsp'</script>");

   

    我的实现方式是:跟普通过滤器的写法一样,跳到某个action,让action决定要跳到的页面,然后在登录页面写上这么一段代码 

<script language="JavaScript">
//判断当前窗口是否有顶级窗口,如果有就让当前的窗口的地址栏发生变化,
//这样就可以让登陆窗口显示在整个窗口了
function loadTopWindow(){
	if (window.top!=null && window.top.document.URL!=document.URL){
		window.top.location= document.URL; 
	}
}
</script>
</head>
<!--在body的写上onload事件要调用的方法-->
<body onload="loadTopWindow()">

 

两种方式都是用js进行实现,各有优缺点

第一种方式的缺点是要Java中写了JavaScript代码,这样的代码风格不是很好,优点是编写简单;

第二种方式的缺点是要发送两次请求,在登陆页面比较大的情况下,这个方式确实不太好,好在一般的登录页面都比较简单,优点是易于维护,在写是时候,只要把这么一段代码复制进去就可以了,所以我个人推荐使用第二种方式。

分享到:
评论

相关推荐

    weblogic设置session超时时间

    WebLogic 设置 Session 超时时间 WebLogic 是一个功能强大且流行的 Java 企业级应用服务器,支持多种方式来设置 Session 的超时时间。在本文中,我们将介绍如何在 WebLogic 中设置 Session 超时时间。 Method 1: ...

    详解SpringBoot中Session超时原理说明

    在 SpringBoot 中,Session 超时是指在一定时间内没有任何操作,Session 就会超时失效,导致用户需要重新登录才可以继续访问页面。这是因为 Session 的超时时间是有限制的,默认情况下是 1800 秒,在这个时间内如果...

    登录超时完整实例、session超时设置、JSP页面会话超时

    本教程将深入探讨"登录超时完整实例",包括如何进行`session超时设置`以及在`JSP页面`中处理会话超时的问题。 首先,我们需要理解什么是登录超时。登录超时是指用户在一定时间内未进行任何操作,系统自动判断该用户...

    JS之Session超时提示代码

    但Session具有生命周期限制,一旦超时,用户就需要重新登录。本篇文章将深入分析一个通过JavaScript(简称JS)实现的Session超时提示逻辑,该逻辑不依赖于服务器端请求,而是利用前端技术监测用户行为并在Session...

    iframe 跨域访问session

    然而,当涉及到跨域时,`iframe` 遇到的问题之一就是无法正常访问父页面或被嵌入页面的`session`。这是因为浏览器的同源策略(Same-Origin Policy)限制了不同源之间的交互,包括`session`和`cookie`。 同源策略是...

    IFrame中Session丢失的解决办法

    设置`mode`属性为`StateServer`,并指定`stateConnectionString`,这使得Session数据不在本地存储,而是通过TCP/IP连接到一个独立的State Server服务,从而避免了由于IFrame环境导致的Session丢失问题。 2. **调整...

    Ajax请求session超时处理流程

    Ajax请求session超时处理流程 java服务器端处理: SessionValidateFilter中修改: if (ServerInfo.isAjax(request)) { request.setAttribute("statusCode", 301); request.setAttribute("message", "Session ...

    .net 和IIS7.5关于Session超时的设置

    .NET 和 IIS7.5 关于 Session 超时的设置是一个重要的议题,尤其是在构建Web应用程序时,确保用户会话的正确管理和安全至关重要。Session是ASP.NET中的一个关键概念,它用于存储用户在网站上浏览期间的状态信息。当...

    JSPsession超时提示

    - 如果从 `epoch` 到 `epoch2` 的时间差大于超时时间,则重定向至登录页面。 ```javascript function CheckSessionStatus(){ var epoch2 = new Date().getTime(); if (epoch2 &gt; epoch + warn_sec && epoch2 ) { ...

    dwz框架实现拦截器 session超时跳转登陆页面

    dwz框架实现拦截器 session超时跳转登陆页面 DWZ框架 struts2拦截器 session超时

    iframe跨域访问时session丢失

    NULL 博文链接:https://thoreau.iteye.com/blog/745100

    .net解决了防止用户重复登陆,session超时

    首先,我们要启用窗体身份验证(Forms Authentication)并设置默认的登录页面。在`web.config`文件中,我们添加以下代码: ```xml ``` 接着,我们设定网站的访问权限。允许所有用户匿名访问网站,但对特定目录...

    session超时踢人补丁源代码

    4. **踢出用户操作**:当检测到Session超时时,源码会执行清理操作,如删除服务器上的Session数据,清空用户Cookie中的Session ID,并重定向用户到登录页面。 5. **提示信息**:为了提供良好的用户体验,系统应告知...

    Jsp中解决session过期跳转到登陆页面并跳出iframe框架的方法

    本文将介绍如何在JSP中设置session超时后跳转到登录页面,并解决iframe框架跳出的问题。 首先,我们考虑如何在session超时后重定向到登录页面。这可以通过使用过滤器(filter)来实现。过滤器是一种可以拦截请求和...

    session 超时

    知识点一:session超时概念及设置 session超时是指用户在...在这种形式中,用户每次登录后,系统会自动创建一个session,保存用户的登录信息,用户在不同页面间切换时无需重新登录,退出系统时关闭session,结束会话。

    php中精确控制session超时时间

    在PHP编程中,控制session的超时时间是一个重要的议题,特别是在需要精确管理用户登录状态的场景下。PHP的默认session超时时间为1440秒(即24分钟),但有时候开发者可能需要自定义更短或更长的超时时间以满足特定...

    登录超时给出提示跳到登录页面(ajax、导入、导出)

    总结,实现登录超时给出提示跳到登录页面,需要结合服务器端的过滤器检查和前端的Ajax响应处理。同时,导入和导出功能为用户提供了数据管理的便利,但也要考虑安全性和效率问题。通过合理的设计和实现,可以提供一个...

    Javaweb项目session超时解决方案

    解决Session超时的问题,需要对所有的/web/请求进行登录拦截,Session超时时跳转到登录页面。可以通过配置Session超时时间来实现这一点。在项目的web.xml中可以进行配置,如下: &lt;!-- 设置Session超时时间 --&gt; ...

    Java中设置session超时(失效)的三种方法

    当用户访问Web应用程序时,服务器创建一个Session对象,用于存储用户特定的信息,如登录状态、购物车内容等。Session的有效期,即超时时间,决定了在多久无活动后,服务器会自动废弃这个Session。在Java中,有三种...

Global site tag (gtag.js) - Google Analytics