关于泛型的查找方式

本文介绍了一个基于.NET的权限验证系统实现,通过用户组、角色和任务类型来判断用户是否具备特定权限。提供了查找用户组、角色的方法及权限比较逻辑。
namespace CSWave.Core.Security
{
    using CSWave.Core;
    using CSWave.Core.Business;
    using CSWave.Core.Component;
    using CSWave.Framework.Utility;
    using System;

    public static class Authentication
    {
        public static UserGroup FindGroupById(int groupId)
        {
            return UserGroupBiz.Current.Find(delegate (UserGroup item) {
                return item.Id == groupId;
            });
        }

        public static UserRole FindRoleByGroupId(int groupId)
        {
            UserGroup group = FindGroupById(groupId);
            if (group == null)
            {
                return null;
            }
            return FindRoleByRoleId(group.RoleId);
        }

        public static UserRole FindRoleByRoleId(int roleId)
        {
            return UserRoleBiz.Current.Find(delegate (UserRole item) {
                return item.Id == roleId;
            });
        }

        public static void HasPermission(ManageTaskType task, AdminAccount user)
        {
            if (!HasPermissionAsBoolen(task, user))
            {
                EXM.Throw(ErrorType.AuthenticationRequest, true);
            }
        }

        public static void HasPermission(UserTaskType task, UserAccount user)
        {
            if (!HasPermissionAsBoolen(task, user))
            {
                EXM.Throw(ErrorType.AuthenticationRequest, true);
            }
        }

        public static bool HasPermissionAsBoolen(ManageTaskType task, AdminAccount user)
        {
            if ((user == null) || (user.Id < 1))
            {
                HttpUtility.Redirect("/Manage/Login.aspx");
                return false;
            }
            bool flag = false;
            int taskFlag = (int) task;
            UserRole role = FindRoleByGroupId(user.GroupId);
            if (role != null)
            {
                flag = PermissionCompare(role, taskFlag);
            }
            if (!flag)
            {
                UserGroup group = FindGroupById(user.GroupId);
                if ((group != null) && (group.ParentId != 0))
                {
                    flag = PermissionCompare(FindRoleByGroupId(group.ParentId), taskFlag);
                }
            }
            return flag;
        }

        public static bool HasPermissionAsBoolen(UserTaskType task, UserAccount user)
        {
            return HasPermissionAsBoolen(task, user.GroupId);
        }

        public static bool HasPermissionAsBoolen(UserTaskType task, int groupId)
        {
            int flag = (int) task;
            return HasPermissionAsBoolen(flag, groupId);
        }

        public static bool HasPermissionAsBoolen(int flag, int groupId)
        {
            bool flag2 = false;
            UserRole role = FindRoleByGroupId(groupId);
            if (role != null)
            {
                flag2 = PermissionCompare(role, flag);
            }
            if (!flag2)
            {
                UserGroup group = FindGroupById(groupId);
                if ((group != null) && (group.ParentId != 0))
                {
                    flag2 = PermissionCompare(FindRoleByGroupId(group.ParentId), flag);
                }
            }
            return flag2;
        }

        public static bool PermissionCompare(UserRole role, int taskFlag)
        {
            if (role == null)
            {
                return false;
            }
            return (role.Permission.IndexOf(string.Format(",{0},", taskFlag)) >= 0);
        }
    }
}

转载于:https://www.cnblogs.com/wxf82610/archive/2008/11/22/1338823.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值