GVKun编程网logo

ajax session过期 页面跳转问题(shiro ajax 过期)

9

本文将分享ajaxsession过期页面跳转问题的详细内容,并且还将对shiroajax过期进行详尽解释,此外,我们还将为大家带来关于ajaxpost请求之后实现页面跳转和带参数跳转问题、ajaxSe

本文将分享ajax session过期 页面跳转问题的详细内容,并且还将对shiro ajax 过期进行详尽解释,此外,我们还将为大家带来关于ajax post请求之后 实现页面跳转和带参数跳转问题、ajax Session失效如何跳转到登录页面、Ajax Session失效跳转登录页面的方法、ajax session过期问题的几个解决方案的相关知识,希望对你有所帮助。

本文目录一览:

ajax session过期 页面跳转问题(shiro ajax 过期)

ajax session过期 页面跳转问题(shiro ajax 过期)

在WEB应用中,一般通过监控SESSION来判断用户是否登录、或是否发呆时间过长。如果SESSION过期或用户未登录,用户再次向服务器请求资源的时候,就跳转(重定向)到登录页面。
  可实际上,用户在请求资源的时候,页面的状态可能有多种:带框架的页面、window.open()函数打开的窗口。这时候跳转(重定向)到登录页面就会有问题。其实可以拿过一个简单的脚本来解决这个问题:

<script type="text/javascript">
if(window.opener){
//若是弹出的打开窗口,刷新父窗口,就关闭本窗口
window.open.reload();
window.close();
}
else{
var topwin = window.parent;
//找到顶层窗口
while(topwin!= topwin.parent){
topwin = topwin.parent;
if(window.parent!=window)
topwin.location.href=
"${pageContext.request.contextpath}/index. jsp ";

</script>

http://www.2cto.com/kf/201109/103416.html

ajax post请求之后 实现页面跳转和带参数跳转问题

ajax post请求之后 实现页面跳转和带参数跳转问题

在回调函数里面处理

$.post(

url,
{method:"regist",userName:$nameEle.val(),email:$emailEle.val(),password:$passwordEle.val()},
function(data) {
//alert(data);
//注册成功页面跳转,
window.location.href ="../client/login.html";
}

);


带参数的跳转方式:

$.post(
url,
{method:"regist",
function(data) {
//alert(data);
//注册成功页面跳转,
window.location.href ="../yiliaoqixie/login.html?name="+$nameEle.val();
}
);


另外一种写法:

<ahref="javascript:dpUpdate('10086')">更新</a>

function doUpdate(relid){
document.location.href= "update.PHP?id=" +id;
}

ajax Session失效如何跳转到登录页面

ajax Session失效如何跳转到登录页面

在Struts应用中,我们发出的请求都会经过 相应的拦截器进行相关处理,一般都会有一个用户登录拦截(Session失效拦截);一般请求的话,如果Session失效时,我们会跳到登录页面,可是如果我们采用AJAX请求时,将会返回登录页面的HTML代码,这肯定不是我们想要的,那么我们如何解决呢?请看以下步骤:

一、建立拦截器

packagecom.xxx.planeap.interceptor;

importjavax.servlet.http.HttpServletRequest;
importjavax.servlet.http.HttpServletResponse;

importorg.apache.log4j.Logger;
importorg.apache.struts2.ServletActionContext;

importcom.opensymphony.xwork2.ActionContext;
importcom.opensymphony.xwork2.ActionInvocation;
importcom.opensymphony.xwork2.ActionSupport;
importcom.opensymphony.xwork2.interceptor.AbstractInterceptor;
importcom.xxx.common.contants.ConstantsKey;
importcom.xxx.common.contants.SessionKey;
importcom.xxx.planeap.domain.User;
importcom.xxx.planeap.security.SecurityContextUtil;

/**
*
*@authorGomaOMA1989@YEAH.NET
*@versionv1.0
*@since2012-05-31

*
*/
publicclassSecurityInterceptorextendsAbstractInterceptor{
privatestaticfinallongserialVersionUID=1L;
privateLoggerlogger=Logger.getLogger(SecurityInterceptor.class);

@Override
publicStringintercept(ActionInvocationinvocation)throwsException{
//TodoAuto-generatedmethodstub

StringclassName=invocation.getAction().getClass().getName();
Stringaction=className.substring(className.lastIndexOf(".")+1,className.length());
StringactionName=invocation.getProxy().getActionName();

Stringresult;
HttpServletRequestrequest=ServletActionContext.getRequest();
HttpServletResponseresponse=ServletActionContext.getResponse();
Stringtype=request.getHeader("X-Requested-With");
Useruser=(User)ActionContext.getContext().getSession().get(SessionKey.CURRENT_USER);
if(user==null){
logger.debug("SecurityCHECKED:NEEDTOLOGIN");
if("XMLHttpRequest".equalsIgnoreCase(type)){//AJAXREQUESTPROCESS
response.setHeader("sessionstatus",ConstantsKey.MSG_TIME_OUT);
result=null;
}else{//norMALREQUESTPROCESS
result=ActionSupport.LOGIN;
}
}else{
logger.debug("SecurityCHECKED:USERHASLOGINED");
SecurityContextUtil.setCurrentUser(user);
booleanhanPerm=SecurityContextUtil.hasPerm(action,actionName);
logger.debug("SecurityCHECKED:PERMISSION---"+action+"."+actionName+"="+hanPerm);
result=invocation.invoke();
}
returnresult;
}
}

二、定义全局AJAX请求结束处理方法

//全局的AJAX访问,处理AJAX清求时SESSION超时

$.ajaxSetup({

contentType:"application/x-www-form-urlencoded;charset=utf-8",

complete:function(XMLHttpRequest,textStatus){

//通过XMLHttpRequest取得响应头,sessionstatus

var sessionstatus=XMLHttpRequest.getResponseHeader("sessionstatus");

if(sessionstatus=="timeout"){

//这里怎么处理在你,这里跳转的登录页面

window.location.replace(PlanEap.getActionURI("login"));

}

}

});

Ajax Session失效跳转登录页面的方法

Ajax Session失效跳转登录页面的方法

在Struts应用中,我们发出的请求都会经过 相应的拦截器进行相关处理,一般都会有一个用户登录拦截(Session失效拦截);一般请求的话,如果Session失效时,我们会跳到登录页面,可是如果我们采用AJAX请求时,将会返回登录页面的HTML代码,这肯定不是我们想要的,那么我们如何解决呢?请看以下步骤:

一、建立拦截器

package com.xxx.planeap.interceptor;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.log4j.Logger;
import org.apache.struts2.ServletActionContext;
import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.ActionSupport;
import com.opensymphony.xwork2.interceptor.AbstractInterceptor;
import com.xxx.common.contants.ConstantsKey;
import com.xxx.common.contants.SessionKey;
import com.xxx.planeap.domain.User;
import com.xxx.planeap.security.SecurityContextUtil;
/**
* 
* @author Goma OMA1989@YEAH.NET
* @version v1.0
* @since 2012-05-31
* 
*/
public class SecurityInterceptor extends AbstractInterceptor {
private static final long serialVersionUID = 1L;
private Logger logger = Logger.getLogger(SecurityInterceptor.class);
@Override
public String intercept(ActionInvocation invocation) throws Exception {
// TODO Auto-generated method stub
String className = invocation.getAction().getClass().getName();
String action = className.substring(className.lastIndexOf(".")+1,className.length());
String actionName = invocation.getProxy().getActionName();
String result;
HttpServletRequest request = ServletActionContext.getRequest();
HttpServletResponse response = ServletActionContext.getResponse();
String type = request.getHeader("X-Requested-With");
User user = (User) ActionContext.getContext().getSession().get(SessionKey.CURRENT_USER);
if (user == null) {
logger.debug("SECURITY CHECKED: NEED TO LOGIN");
if ("XMLHttpRequest".equalsIgnoreCase(type)) {// AJAX REQUEST PROCESS
response.setHeader("sessionstatus", ConstantsKey.MSG_TIME_OUT);
result = null;
} else {// NORMAL REQUEST PROCESS
result = ActionSupport.LOGIN;
}
} else {
logger.debug("SECURITY CHECKED: USER HAS LOGINED");
SecurityContextUtil.setCurrentUser(user);
boolean hanPerm = SecurityContextUtil.hasPerm(action, actionName);
logger.debug("SECURITY CHECKED: PERMISSION---"+action+"."+actionName+"="+hanPerm);
result = invocation.invoke();
}
return result;
}
}

二、定义全局AJAX请求结束处理方法

//全局的AJAX访问,处理AJAX清求时SESSION超时
$.ajaxSetup({
contentType:"application/x-www-form-urlencoded;charset=utf-8",
complete:function(XMLHttpRequest,textStatus){
//通过XMLHttpRequest取得响应头,sessionstatus 
var sessionstatus=XMLHttpRequest.getResponseHeader("sessionstatus"); 
if(sessionstatus=="timeout"){
//这里怎么处理在你,这里跳转的登录页面
window.location.replace(PlanEap.getActionURI("login"));
}
}
});

也就是ajax发送请求时如果拦截返回一个表示就跳转,否则执行正常操作。

您可能感兴趣的文章:
  • express如何解决ajax跨域访问session失效问题详解
  • 使用Ajax时处理用户session失效问题的解决方法
  • 完美解决ajax访问遇到Session失效的问题
  • ajax 操作全局监测,用户session失效的解决方法
  • ajax在兼容模式下失效的快速解决方法
  • Ajax请求session失效该如何解决
  • 如何解决ajax在google chrome浏览器上失效
  • ajax请求Session失效问题
  • ajax更新数据后,jquery、jq失效问题
  • 解决IE9下JQuery发送ajax请求失效的方法

ajax session过期问题的几个解决方案

ajax session过期问题的几个解决方案

如处理不当会影响用户体验,也有可能产生莫名的问题。
结合自己的思考和网上相关内容的参考,给出如下解决方案。每个方案都有不同的优缺点,欢迎
大家指正。
方案1:检查AJAX返回的返回的内容是否有<html>标签
在web系统中,当session过期时,当用户有操作的时候,此时系统一般会返回登陆界面。
让用户重新输入用户名和密码。当session过期的时候,AJAX请求返回的内容应该是登陆界面的页面
内容(即登陆界面的页面的html代码)。通过判断返回内容是否用<html>来判断session是否过期。
var result=request.responseText;/* ajax返回的内容*/
if(result.indexOf(''<HTML>'')>-1){/*返回内容中有html标签*/}
或者
var r=/<html>/ig;
if(r.test(result)){/*返回内容中有html标签*/}
通过上面的方法可以判断session是否过期,然后根据具体的业务进行异常处理。
方案2:返回的结果中有session是否过期的标志。也有人称为true/false模式
此解决方案一般结合json使用。
如返回的结果是:
var res={
"result":true,/*session没有过期,false(session过期)*/
"data" :""/*其它数据*/
}
if(res["result"])
{
/*session没有过期*/
}else{
/*session过期*/
}
方案3:利用时间戳
在页面上搞个全局变量
var startDate; /*ajax最近一次访问服务器的时间,Date类型*/
if(new Date().getTime()-startDate.getTime()<30*60*1000)
{
/*假设session过期的时间30分钟*/
/*session没有过期*/
}else{
/*session过期*/
}
哈哈!Do not trust the client
方案4:延长session过期时间
此方案有性能问题
4.1:延长session过期时间
4.2:client轮循server。(AJAX轮循server或client,server保持长连接)
您可能感兴趣的文章:
  • jQuery ajax全局函数处理session过期后的ajax跳转问题
  • ajax实现session不过期(避免页面过期的现象)
  • 浅析ajax请求json数据并用js解析(示例分析)
  • 跨域请求之jQuery的ajax jsonp的使用解惑
  • 原生 JS Ajax,GET和POST 请求实例代码
  • js每隔5分钟执行一次ajax请求的实现方法
  • JS实现定时任务每隔N秒请求后台setInterval定时和ajax请求问题
  • 详解JavaScript for循环中发送AJAX请求问题
  • 分享JavaScript监听全部Ajax请求事件的方法
  • 浅谈js的ajax的异步和同步请求的问题
  • JS Ajax请求会话过期处理问题解决方法分析

关于ajax session过期 页面跳转问题shiro ajax 过期的介绍现已完结,谢谢您的耐心阅读,如果想了解更多关于ajax post请求之后 实现页面跳转和带参数跳转问题、ajax Session失效如何跳转到登录页面、Ajax Session失效跳转登录页面的方法、ajax session过期问题的几个解决方案的相关知识,请在本站寻找。

本文标签: