mvc下ajax请求遇到session超时简单处理方式
2016-08-16 18:12
756 查看
(第一次写博客,有点糙,大家凑合着看吧 ==)
这两天开发遇到有一个问题,ajax请求遇到session超时只返回登陆页的html,我原来的页面跳转代码是这样的:
项目采用的是mvc模式,上面代码简单来说就是写了一个基类控制器,然后所有的控制器都继承这个基类控制器,基类控制器中重写了OnActionExecuting方法,然后方法中判断当前登录信息是否为空,为空则跳转至登陆页,问题来了,就像我刚才说的,如果是正常的请求这里会跳转到登陆页,但如果是ajax请求就只会返回登陆页的html无法跳页面,我想要实现的效果是:所有的ajax请求如果发现session超时前台就跳页面,找了挺多资料都好像说前台对ajax请求进行统一封装,统一拦截处理,但我的项目已经完成了,这样的地方太多了,如果所有都要改想想都觉得麻烦,参考了一些资料后找到了相对简单的处理方式,上代码!
基类控制器:
其实就是在之前的基础上添加了对ajax请求的判断。
前端公用js中添加:
到此,我想要的功能就完成了。
本文来自:http://blog.csdn.net/yeyicsdn/article/details/50032787
这两天开发遇到有一个问题,ajax请求遇到session超时只返回登陆页的html,我原来的页面跳转代码是这样的:
/// <summary> /// 重写基类在Action执行之前的事情 /// </summary> /// <param name="filterContext">重写方法的参数</param> protected override void OnActionExecuting(ActionExecutingContext filterContext) { //得到用户登录的信息 CurrentUserInfo = Session["UserInfo"] as Comm_Operator; //判断用户是否为空 if (CurrentUserInfo == null) { //以下两句代码无法彻底截断请求、还会继续请求原来的action //filterContext.HttpContext.Response.Redirect("/Login/Index"); //filterContext.HttpContext.Response.End(); //下面的代码可以截断原来的action请求 filterContext.Result = RedirectToRoute("Default", new { Controller = "Login", Action = "Index" }); } base.OnActionExecuting(filterContext); }
项目采用的是mvc模式,上面代码简单来说就是写了一个基类控制器,然后所有的控制器都继承这个基类控制器,基类控制器中重写了OnActionExecuting方法,然后方法中判断当前登录信息是否为空,为空则跳转至登陆页,问题来了,就像我刚才说的,如果是正常的请求这里会跳转到登陆页,但如果是ajax请求就只会返回登陆页的html无法跳页面,我想要实现的效果是:所有的ajax请求如果发现session超时前台就跳页面,找了挺多资料都好像说前台对ajax请求进行统一封装,统一拦截处理,但我的项目已经完成了,这样的地方太多了,如果所有都要改想想都觉得麻烦,参考了一些资料后找到了相对简单的处理方式,上代码!
基类控制器:
/// <summary> /// 重写基类在Action执行之前的事情 /// </summary> /// <param name="filterContext">重写方法的参数</param> protected override void OnActionExecuting(ActionExecutingContext filterContext) { //得到用户登录的信息 CurrentUserInfo = Session["UserInfo"] as Comm_Operator; //判断用户是否为空 if (CurrentUserInfo == null) { if (filterContext.HttpContext.Request.IsAjaxRequest()) { Response.AppendHeader("sessionstatus", "timeout"); Response.End(); } else { //以下两句代码无法彻底截断请求、还会继续请求原来的action //filterContext.HttpContext.Response.Redirect("/Login/Index"); //filterContext.HttpContext.Response.End(); //下面的代码可以截断原来的action请求 filterContext.Result = RedirectToRoute("Default", new { Controller = "Login", Action = "Index" }); } } else base.OnActionExecuting(filterContext); }
其实就是在之前的基础上添加了对ajax请求的判断。
前端公用js中添加:
//全局的ajax访问,处理ajax清求时sesion超时 $.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 = "/Login/Index"; } } });
到此,我想要的功能就完成了。
本文来自:http://blog.csdn.net/yeyicsdn/article/details/50032787
相关文章推荐
- mvc下ajax请求遇到session超时简单处理方式
- Session超时后,Ajax请求处理方式
- Session超时后,Ajax请求处理方式
- mvc下ajax请求遇到session超时简单处理方式
- 当 jquery 发送 ajax 请求的时候遇到服务端session过期超时返回 302 跳转登陆页面的时候怎么办的处理方法
- DWZ(JUI) 教程 Ajax请求session超时处理流程
- ajax请求 session过期跳转首页的两种处理方式
- Session超时或无效,处理ajax请求
- 当Ajax请求遇到Session超时
- ajax异步请求,session超时处理
- DWZ(JUI) 教程 Ajax请求session超时处理流程
- Ajax请求处理Session超时
- Ajax请求Session超时的处理
- session超时,处理ajax请求
- 在Ajax请求中处理登录session超时的方法
- ASP.NET WebForm 之 Ajax 请求后端处理 概述 ASP.NET 在MVC中的用途非常广泛,操作起来也非常简单。前台请求异步请求 Controlle
- Ajax请求session超时处理流程(DWZ)
- DWZ框架Ajax请求session超时处理
- 一款简单实用的请求过滤以及session超时处理
- session 超时,处理ajax请求