public override void OnActionExecuting(ActionExecutingContext filterContext)
{
...
if (needToRedirect)
{
...
filterContext.Result = new RedirectResult(url);
return;
}
...
}
It can be done this way as well:
filterContext.Result = new RedirectToRouteResult(
new RouteValueDictionary
{
{"controller", "Home"},
{"action", "Index"}
}
);
Create a separate class,
public class RedirectingAction : ActionFilterAttribute
{
public override void OnActionExecuting(ActionExecutingContext context)
{
base.OnActionExecuting(context);
if (CheckUrCondition)
{
context.Result = new RedirectToRouteResult(new RouteValueDictionary(new
{
controller = "Home",
action = "Index"
}));
}
}
}
Then, When you create a controller, call this annotation as
[RedirectingAction]
public class TestController : Controller
{
public ActionResult Index()
{
return View();
}
}
If the redirected controller inherit from the same baseController
where we override the OnActionExecuting
method cause recursive loop. Suppose we redirect it to login action of account controller, then the login action will call OnActionExecuting
method and redirected to the same login action again and again
... So we should apply a check in OnActionExecuting
method to check weather the request is from the same controller if so then do not redirect it login action again. here is the code:
protected override void OnActionExecuting(ActionExecutingContext filterContext)
{
try
{
// some condition ...
}
catch
{
if (filterContext.Controller.GetType() != typeof(AccountController))
{
filterContext.Result = new RedirectToRouteResult(new RouteValueDictionary {
{ "controller", "Account" },
{ "action", "Login" }
});
}
}
}
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With