• ASP.NET MVC- ActionFilter的使用


      ActionFilter是穿插在Action执行过程,在Action执行前后提供扩展的功能。ActionFilter用途非常的广,用在页面压缩、缓存、错误处理,登陆验证。

      ActionFilter的实现需要继承自ActionFilterAttribute抽象类,并且覆盖需要使用的方法。

      ActionFilterAttribute类中有四个可重的方法,分别是OnActionExecuting,OnActionExecuted,OnResultExecuting,OnResultExecuted。

      这四个方法的执行顺序是 OnActionExecuting->OnActionExecuted->OnResultExecuting->OnResultExecuted

      实现步骤

      1.先建立一个Filter文件夹,在里面新建一个类FilterDemo

      代码如下:

    using System.Web.Mvc;
    
    namespace MvcApplication2.Filter
    {
        public class DemoFilter : ActionFilterAttribute
        {
            public override void OnActionExecuting(ActionExecutingContext filterContext)
            {
                HttpContext.Current.Response.Write("OnActionExecuting:正要准备执行Action的时候但还未执行时执行");
            }
    
            public override void OnActionExecuted(ActionExecutedContext filterContext)
            {
                HttpContext.Current.Response.Write("OnActionExecuted:Action执行时但还未返回结果时执行");
            }
    
            public override void OnResultExecuting(ResultExecutingContext filterContext)
            {
                HttpContext.Current.Response.Write("OnResultExecuting:OnResultExecuting也和OnActionExecuted一样,但前者是在后者执行完后才执行");
            }
    
            public override void OnResultExecuted(ResultExecutedContext filterContext)
            {
                HttpContext.Current.Response.Write("OnResultExecuted:是Action执行完后将要返回ActionResult的时候执行");
            }
        }
    }

      2.然后在Controller里,加上[DemoFilter]标记,则在执行这个Action的时候会先进入FilterDemo类里,执行里面的方法

            [DemoFilter]
            public ActionResult FilterDemo()
            {
                return View();
            }
  • 相关阅读:
    Java程序员极力推荐的springboot全家桶干货系列——收藏必会系列
    mysql 远程连接数据库的二种方法
    mysql取以当前时间为中心的任意时间段的时间戳
    使用sql语句,查询 mysql 的安装地址
    MyEclipse中点击Deploy MyEclipse J2EE Project to Server无响应解决方法
    使用DOS访问数据库详解
    mysql查询字段为null 返回0
    MySQL触发器Trigger实例篇
    JAVA汉字转拼音(取首字母大写)
    阿里云上传文件
  • 原文地址:https://www.cnblogs.com/cxeye/p/4985246.html
Copyright © 2020-2023  润新知