• MVC过滤器---身份验证过滤器


    身份验证过滤器的用法(一)

    1、首先创建一个自己定义的过滤类继承MVC身份验证过滤类,重写OnAuthorization方法

      public class MyAuthorization:AuthorizeAttribute
        {
            public override void OnAuthorization(AuthorizationContext filterContext)
            {
                //如果保留如下代码,则会运行.net framework定义好的身份验证,如果希望自定义身份验证,则删除如下代码
                //base.OnAuthorization(filterContext);
    
                //如果希望跳转到另外一个页面,需要使用Result,而不是使用Response.Redirect(),第二种方案不会让服务器端停止执行
                //filterContext.Result=new RedirectResult(UrlHelper.GenerateUrl("","Login","UserInfo",""));
    
                //获取路由数据:当前上下文匹配到路由规则后,得到的一个对象
                //filterContext.RouteData
    
                //获取上下文
                filterContext.HttpContext.Response.Write("123");
            }
        }

    2、在控制器中行为上标记特性,标记的行为会执行过滤器  没标记的不会执行

    [MyAuthorization]:当前行为在执行前,会执行身份验证过滤器
            
            public ActionResult Index()
            {
                throw  new Exception("");
                return View();
            }
           
            public ActionResult Show()
            {
                return View();
            }

    3、控制器中所有的行为都要执行此过滤验证时,在控制器上标记特性

       //[MyAuthorization]//当前控制器下的所有行为,都被应用了这个过滤器
        public class HomeController : MyBaseController//Controller
        {
            //
            // GET: /Home/
            //[MyAuthorization]:当前行为在执行前,会执行身份验证过滤器
            
            public ActionResult Index()
            {
                throw  new Exception("");
                return View();
            }
           
            public ActionResult Show()
            {
                return View();
            }

    4、如果所有的控制器都要执行过滤器验证 则在FilterConfig文件中注册

     public static void RegisterGlobalFilters(GlobalFilterCollection filters)
            {
    
                //在全局中注册过滤器,则所有控制器的所有行为,都会执行这个过滤器
                //filters.Add(new MyAuthorization());
    
            }

    身份验证过滤器的用法(二)

    1、 过滤器的第二种实现方式:重写控制器的方法,这样,会应用于所有的行为(该控制器中),不能控制其中的某个行为的执行

     protected override void OnAuthorization(AuthorizationContext filterContext)
            {
                filterContext.HttpContext.Response.Write("456");
            }

    2、如果要做登录验证,在FilterConfig中注册全局的过滤器,登录首页不需要,会死循坏登不进去,用标记特性的方式太累

      可以自己定义一个控制器的类。

     public class MyBaseController : Controller
        {
            //过滤器的第二种实现方式:重写控制器的方法,这样,会应用于所有的行为
            protected override void OnAuthorization(AuthorizationContext filterContext)
            {
                filterContext.HttpContext.Response.Write("456");
            }
    
           
        }

    3、让要实现过滤的控制器继承我们定义的控制器

     public class HomeController : MyBaseController//Controller
        {
            //
            // GET: /Home/
                 
            public ActionResult Index()
            {
                throw  new Exception("");
                return View();
            }
           
            public ActionResult Show()
            {
                return View();
            }
            
        }
  • 相关阅读:
    反射 Reflect Modifier 修饰符工具类
    【泛型】Generic 参数化类型 类型转换
    泛型 Generic 类型擦除引起的问题及解决方法
    注解 Annotation 简介 总结 MD
    反射 Reflect Class 基础 API MD
    【Type】类型 ParameterizedType
    Java中浮点类型的精度问题 double float
    jQuery之$.ajax()方法详解及实例
    pace.js – 加载进度条插件
    在线代码编辑、保存与运行网址推荐
  • 原文地址:https://www.cnblogs.com/Jenkin/p/7536768.html
Copyright © 2020-2023  润新知