以前我們總是會寫一個基類也叫父類來判斷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過期而報紅頁面了!