Asp.Net MVC3 简单入门第一季(三)详解Controller之Filter

http://www.cnblogs.com/fly_dragon/archive/2011/06/15/2081063.html

[AttributeUsage(AttributeTargets.Class | AttributeTargets.Method, AllowMultiple = false, Inherited = true)]
    public sealed class CheckLogin : ActionFilterAttribute
    {
        public override void OnActionExecuting(ActionExecutingContext filterContext)
        {
            if (filterContext.HttpContext.Session != null)
            {
                if (filterContext.HttpContext.Session.IsNewSession)
                {
                    //LogFormatHelper.LogRequestParams("filterContext.HttpContext.Session.IsNewSession");
                    filterContext.Result = new RedirectToRouteResult(new RouteValueDictionary(new { Controller = "Account", Action = "Login" }));
                }
            }
        }

    }

Global.asax

protectedvoid Application_Start()

        {

FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);

}

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

        private string actionName = string.Empty;
        private Stopwatch sw = null;
        public override void OnActionExecuting(ActionExecutingContext filterContext)
        {
            sw = Stopwatch.StartNew();
            actionName = filterContext.ActionDescriptor.ActionName;
            string function = actionName + " Start...";
            if (filterContext.ActionParameters.Count == 0)
            {
                LogFormatHelper.LogRequestParams(function);
            }
            else
            {
                object[] objs = new object[filterContext.ActionParameters.Count];
                int i = 0;
                foreach( var dic in filterContext.ActionParameters){
                    objs[i++] = dic.Value;
                }
                LogFormatHelper.LogRequestParams(function, objs);
            }
            base.OnActionExecuting(filterContext);
        }


        public override void OnResultExecuted(ResultExecutedContext filterContext)
        {
            base.OnResultExecuted(filterContext);
            string function = actionName + " End";
            StringBuilder sb = new StringBuilder();
            foreach (var key in filterContext.RouteData.Values.Keys)
            {
                sb.AppendFormat("{0} = {1}", key, filterContext.RouteData.Values[key]).AppendLine();
            }
            string str = filterContext.RouteData.Values.ToString();
            LogFormatHelper.LogRequestParams(function, sw.Elapsed , sb.ToString() );

            if (filterContext.Exception != null)
            {
                LogFormatHelper.LogServiceError(filterContext.Exception, actionName);
            }
            
        }

    }


 MVC系统过滤器、自定义过滤器
http://www.cnblogs.com/kissdodog/archive/2013/05/21/3090513.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值