ASP.NET-属性与过滤器

目的:在调用操作之前或者之后执行特定的逻辑代码
系统定义:
1.日志记录
2.防图像盗链 
3.爬虫
4.本地化,用于设定区域设置
5.动态操作,用于将操作注入到控制器当中
用来过滤HTTP请求
高级编程Attribute的一种特例
1.AuthorizeAttribute通过身份验证和授权(可选)限制访问
2.HandleErrorAttribute制定如何处理由操作方法引起的异常
3.OutputCacheAttribute提供输出缓存
4.RequireHttpsAttribute强制请求通过HTTPS重新发送
过滤器的顺序就是按照下面的顺序来执行的


也可以在app_start中加入这个代码来让所有的action实现这个方法
 
   
  1. public static void RegisterGlobalFilters(GlobalFilterCollection filters)
  2. {
  3. filters.Add(new HandleErrorAttribute());
  4. filters.Add(new logFilterAttribute()); //这一行是新加入的
  5. }


在FilterConfig中添加新的覆写过滤规则

679411-20160322232450089-1477468813.png

覆写OnActionExecuting方法,然后在Controller的action中只要添加 [logFilter] 属性就可以直接使用过滤器方法

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
public class logFilterAttribute : ActionFilterAttribute
{
     // 在方法执行之前拦截
     public override void OnActionExecuting(ActionExecutingContext filterContext)
     {
         //跳转 登录页面
         if (filterContext.HttpContext.Session[ "UserName" ] == null )
         {
             filterContext.Result = new RedirectToRouteResult(
                                    new RouteValueDictionary
                            {
                                { "Controller" , "Account" },
                                   { "Action" , "Login" }
                                             });
         }
         base .OnActionExecuting(filterContext);
       
     }
 
}
1
2
3
4
5
[Authorize]
         public ActionResult TestAuthorize()
         {
             return View();
         }














转载于:https://www.cnblogs.com/weloveshare/p/5309112.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值