zoukankan      html  css  js  c++  java
  • 自定义授权筛选器

    Demo

        [AttributeUsage(AttributeTargets.Method | AttributeTargets.Class, Inherited = true, AllowMultiple = true)]
        public class AdminAuthorizeAttribute : FilterAttribute, IAuthorizationFilter
        {
            public void OnAuthorization(AuthorizationContext filterContext)
            {
                if (SkipAuthorization(filterContext))
                {
                    return;
                }
                if (filterContext == null)
                    throw new ArgumentNullException("filterContext");
    
                //判断是否已登陆
                if (HttpContext.Current == null ||
                    !HttpContext.Current.Request.IsAuthenticated ||
                    !(HttpContext.Current.User.Identity is FormsIdentity))
                {
                    filterContext.Result = new HttpUnauthorizedResult();
                }
                else
                {
                    //判断角色权限
                    var authenticationService = DependencyResolver.Current.GetService<IFormsAuthenticationService>();
                    var roleRelationFunction = new List<CustomerRoleFunction>();
                    var controllerName = filterContext.RouteData.Values["controller"].ToString();
                    var actionName = filterContext.RouteData.Values["action"].ToString();
                    var customer = authenticationService.GetCustomer();
                    if (customer != null)
                    {
                        roleRelationFunction.AddRange(customer.CustomerRoles.SelectMany(roles => roles.CustomerRoleFunctions));
                    }
                    if (!roleRelationFunction.Any(c => c.ActionName == actionName && c.ControllerName == controllerName))
                    {
                        HandleUnauthorizedRequest(filterContext, "你无此权限,如需要请通知管理员添加,点击返回");
                    }
                }
            }
    
            private void HandleUnauthorizedRequest(AuthorizationContext filterContext, string message)
            {
                var content = new ContentResult
                {
                    Content = string.Format("<a href='javascript:history.go(-1);'>{0}</a>", message)
                };
                filterContext.Result = content;
            }
    
            /// <summary>
            /// 过滤 AllowAnonymousAttribute 特性
            /// </summary>
            /// <param name="filterContext"></param>
            /// <returns></returns>
            private static bool SkipAuthorization(AuthorizationContext filterContext)
            {
                Contract.Assert(filterContext != null);
    
                return filterContext.ActionDescriptor.GetCustomAttributes(typeof(AllowAnonymousAttribute), true).Any()
                       || filterContext.ActionDescriptor.ControllerDescriptor.GetCustomAttributes(typeof(AllowAnonymousAttribute), true).Any();
            }
        }
  • 相关阅读:
    深入理解JVM(5)——垃圾收集和内存分配策略
    深入理解JVM(4)——对象的创建和访问
    深入理解JVM(3)——类加载机制
    深入理解JVM(2)——运行时数据区
    深入理解JVM(1)——栈和局部变量操作指令
    文本对比
    LRUCache
    linux服务器间文件夹拷贝
    java实现sftp客户端上传文件夹的功能
    sopUI上手教程
  • 原文地址:https://www.cnblogs.com/ideacore/p/7600850.html
Copyright © 2011-2022 走看看