ASP.NET MVC 利用ActionFilterAttribute来判断用户是否登陆等等

本文介绍了如何使用ActionFilterAttribute实现权限控制,确保用户在访问特定Action前必须满足登录条件。通过自定义CheckLoginAttribute过滤器,实现了在访问AdminIndex Action前的登录验证,并在未登录情况下进行了错误跳转。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ActionFilterAttribute是Action过滤类,该属于会在执行一个action之前先执行.而ActionFilterAttribute是
VC的一个专门处理action过滤的类.基于这个原理,
假设某个action:AdminIndex,我们给该Action的最起码访问要求是用户必须是登陆状态.那么,我们要做的工作就是在
[CheckLogin()]
//在该Action上面加一个判断
public ActionResult 
AdminIndex()
{
    
return View();
// end 
AdminIndex

上面说了,ActionFilterAttribute是过滤基类,所以CheckLogin()判断要继承ActionFilterAttribute如下:
public class 
CheckLoginAttribute : ActionFilterAttribute
{
    
public 
CheckLoginAttribute()
     {}
// end class 
CheckLoginAttribute

在ActionFilterAttribute基类中有个抽象方当
public abstract void 
OnActionExecuting(ActionExecutingContext 
filterContext);
顾名思义就是指当要执行一个Action之前要做啥工作.在CheckLoginAttribute继承主类后,要将该OnActionExecuting(..)方法重写如:
public override void 
OnActionExecuting(ActionExecutingContext filterContext)
{} 
// end 
Action

这样的话,我们就可以将我们想做的处理写在该方法里头.如:
public override void 
OnActionExecuting(ActionExecutingContext filterContext)
{
    
// 
如果用户没有登陆

    if(!UserLogin.IsLogined) 
     {
       
// 处理方法
        
ErrorRedirect(filterContext); 
       
return;
      
}
// end 
if

}
// 错误处理方法
private void 

ErrorRedirect(ActionExecutingContext filterContext)
{
     
filterContext.Result 
= new RedirectToRouteResult("Default"new 
RouteValueDictionary(
new { controller = "Home", action 
= 
"Default" }));
// end 
ErrorRedirect

当执行ErrorRedirect方法时,它会自己选择指定的Route并跳转到非AdminIndex的Action中
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值