zoukankan      html  css  js  c++  java
  • MVC session过期如何处理跳转(转)

     

    以前我们总是会写一个基类也叫父类来判断session是否已过期然后跳转到指定的错误页面或者登陆界面,然后让所有的页面都继承这个基类,但是当我们应用到MVC项目中时,发现该方法并不会起作用。这时我们可以这么做:

    1.建一个类,如下

    using System;
    using System.Web.Mvc;
    using System.Web.Routing;
     
    namespace CheckInManagerSystem.Controllers
    {
        public class CheckLogin : ActionFilterAttribute
        {
            public override void OnActionExecuting(ActionExecutingContext filterContext)
            {
                if (filterContext.HttpContext.Session != null)
                {
                    if (filterContext.HttpContext.Session.IsNewSession)
                    {
                        var sessionCookie = filterContext.HttpContext.Request.Headers["Cookie"];
                        if ((sessionCookie != null) && (sessionCookie.IndexOf("ASP.NET_SessionId", StringComparison.OrdinalIgnoreCase) >= 0))
                        {
                            filterContext.Result = new RedirectToRouteResult(new RouteValueDictionary(new { Controller = "Account", Action = "LogOff" }));//这里是跳转到Account下的LogOff,自己定义
                        }
                    }
                }
            }
        }
    }

    2.在每个用到session的Action前增加这个[CheckLogin()],如

    [CheckLogin()]
    public ActionResult Details(int userid)
    {
      ViewDataLoad();
        return View(_context.GetUserById(userid));
    }

      这样就OK啦!不会再因为session过期而报红页面了!

  • 相关阅读:
    m113
    无题
    m102 SE赛
    m101 真*sb($huge 全场最瞎$)
    m100 的坑
    m99 然而并没有想出来标题!
    m98 lsc rp-- 赛
    csps2019AFO祭
    csps考前的一些总结(然而可能并没有用)
    低错总结
  • 原文地址:https://www.cnblogs.com/zemax/p/5607561.html
Copyright © 2011-2022 走看看