2014-04-08 14 views
5

problema dichiarazione:applicazione del filtro misura che a livello globale eccezione Redirect Loop in MVC

Sto cercando di reindirizzare utente alla pagina di login se la sessione scade o se l'utente cerca di accedere qualsiasi visualizzazione senza effettuare l'accesso MVC 4 utilizzando rasoio .

  • Invece di applicare filtro azione globalmente in filter.config se uso attributo di filtro per ogni modalità di azione funziona bene.
  • Non voglio applicare questo filtro azioni a ogni singolo metodo .

voglio applicarlo globally.How per evitare loop di reindirizzamento applicando filtro azione a livello globale ?? Come raggiungere questo?

controller Login:

//Get Method 
public ActionResult Index(string returnUrl) 
{ 
    ViewBag.ReturnUrl = returnUrl; 
    return View(); 
} 

//Post Method 
[HttpPost] 
public ActionResult Index(LoginModel loginModel, string returnUrl) 
{ 
    if (ModelState.IsValid) 
    { 
     objLoginDC.LoginID = loginModel.LoginID; 
     objLoginDC.Password = loginModel.Password; 
     if (objSvcMasterConfig.IsValid(objLoginDC)) 
     { 
      var varLoginTenantUserDetails = objSvcMasterConfig.GetLoginUserDetails(objLoginDC); 
      Session["User"] = varLoginUserDetails[0]; 
      FormsAuthentication.SetAuthCookie(objLoginDC.LoginID, objLoginDC.RememberMe); 

      return RedirectToLogin(returnUrl); 
     } 
     else 
     { 
      ModelState.AddModelError("", "The Log In ID or Password provided is incorrect."); 
     } 
    } 

    return View(loginModel); 
} 

Filtri (Operazione filtro):

[AttributeUsage(AttributeTargets.Class | AttributeTargets.Method, Inherited = true, AllowMultiple = false)] 
public class CheckUserSessionAttribute : ActionFilterAttribute 
{ 
    public override void OnActionExecuting(ActionExecutingContext filterContext) 
    { 
     HttpSessionStateBase session = filterContext.HttpContext.Session; 
     var user = session["User"]; 

     if (((user == null) && (!session.IsNewSession)) || (session.IsNewSession)) 
     { 
      session.RemoveAll(); 
      session.Clear(); 
      session.Abandon(); 

      filterContext.Result = new RedirectToRouteResult(new RouteValueDictionary { { "controller", "Login" }, { "action", "Index" } }); 
     } 
     base.OnActionExecuting(filterContext); 
    } 
} 

Filtrare Config.cs:

public class FilterConfig 
{ 
    public static void RegisterGlobalFilters(GlobalFilterCollection filters) 
    { 
     filters.Add(new HandleErrorAttribute()); 
     filters.Add(new Filters.CheckUserSessionAttribute()); 
    } 
} 

risposta

3

Si potrebbe cercare di non eseguire la logica del filtro quando il controller è Accesso e l'azione è Indice:

[AttributeUsage(AttributeTargets.Class | AttributeTargets.Method, Inherited = true, AllowMultiple = false)] 
public class CheckUserSessionAttribute : ActionFilterAttribute 
{ 

    public override void OnActionExecuting(ActionExecutingContext filterContext) 
    { 
     //do not execute the filter logic for Login/Index 
     if (filterContext.RouteData.GetRequiredString("controller").Equals("LogIn", StringComparison.CurrentCultureIgnoreCase) 
      && filterContext.RouteData.GetRequiredString("action").Equals("Index", StringComparison.CurrentCultureIgnoreCase)){ 
      return; 
     } 

     HttpSessionStateBase session = filterContext.HttpContext.Session; 
     var user = session["User"]; 

     if (((user == null) && (!session.IsNewSession)) || (session.IsNewSession)) 
     { 
      session.RemoveAll(); 
      session.Clear(); 
      session.Abandon(); 

      filterContext.Result = new RedirectToRouteResult(new RouteValueDictionary { { "controller", "Login" }, { "action", "Index" } }); 
     } 
     base.OnActionExecuting(filterContext); 
    } 
}