C#中控制权限的逻辑写法

c 复制代码
if (!parmsEntity.ContainsKey("_NoViewData_") && objEntity != null && objEntity.IaUnusual)
{
    var viewRoleUsers = GetViewRoleUsers(oc, workId);
    if (viewRoleUsers.All(r => r.RoleUserCode != "-1"))
    {
        var roleUserCodes = viewRoleUsers.Select(r => r.RoleUserCode).ToList();
        roleUserCodes.Add(workId);
        if ((config == null || (config != null && !config.Value.Equals("1"))) && !roleUserCodes.Contains("001"))
        {
            roleUserCodes.Add("001");
        }
        var roleUserStr = string.Join("','", roleUserCodes.Distinct());

        StringBuilder stringBuilder = new StringBuilder();
        bool hasCreateUser = hasCreateUserForSQL(vQueryString, paras, oc, stringBuilder);

        if (hasCreateUser)
        {
            stringBuilder.AppendFormat(@"  where  _ViewData_.CreateUser in('{0}')", roleUserStr);
        }
        else
        {
            stringBuilder.Append(" where 1=2");
        }

        if (!objEntity.ViewRoleField.IsNullOrEmpty())
        {
            var tmpField = objEntity.ViewRoleField.Split(';');
            foreach (var item in tmpField)
            {
                stringBuilder.AppendFormat(@" or _ViewData_.{1} in('{2}')", vQueryString, item, roleUserStr);
            }
        }
        vQueryString = stringBuilder.ToString();

    }

}

接下来我为大家讲解大体逻辑:

第一步:查询用户角色关系

c 复制代码
public List<W_SYS_ViewRoleUser> GetViewRoleUsers(string oc, string uc)
{
    string key = (oc + uc).ToMD5Encrypt16();
    var obj = cache.Hash_Get<List<W_SYS_ViewRoleUser>>("GetViewRoleUsers", key);
    if (obj == null)
    {
        obj = this.FindList<W_SYS_ViewRoleUser>(r => r.ObjectCode.Equals(oc) && r.UserCode.Equals(uc)).ToList();
        cache.Hash_Set<List<W_SYS_ViewRoleUser>>("GetViewRoleUsers", key, obj);
    }
    return obj;
}

​​参数​​:oc(对象/模块代码),workId(当前用户工号)

​​查询​​:从W_SYS_ViewRoleUser表查询该用户在该模块下的​​角色-用户映射关系​​

​​缓存​​:使用MD5缓存键提升性能

第二步:排除超级管理员

c 复制代码
if (viewRoleUsers.All(r => r.RoleUserCode != "-1"))

如果查询结果中包含RoleUserCode = "-1"的记录,说明是​​超级管理员​​,跳过所有权限控制

如果没有-1,说明是​​普通用户​​,继续权限控制

第三步:构建权限用户列表

c 复制代码
var roleUserCodes = viewRoleUsers.Select(r => r.RoleUserCode).ToList();
roleUserCodes.Add(workId);  // 添加自己

viewRoleUsers中的RoleUserCode就是​​有权限查看的用户工号列表​​

这个列表代表了:​​当前用户可以看到哪些用户创建的数据​

第四步:添加特殊权限

c 复制代码
if (!roleUserCodes.Contains("001")) { roleUserCodes.Add("001"); }

虚拟工号"001"有特殊权限(如系统管理员)

完整权限逻辑总结

​​查询权限配置​​:获取当前用户在当前模块能查看哪些用户的数据

​​超级管理员判断​​:如果有-1权限,跳过所有限制

​​构建权限列表​​:包含同角色用户 + 自己 + 虚拟管理员

​​生成SQL条件​​:只能查看权限列表中用户创建的数据

实际应用示例

假设用户UserA在项目模块:

能查看:UserA(自己)、UserB、UserC、001创建的项目数据

​​不能查看​​:UserD、UserE等其他用户创建的数据

这样就实现了​​基于角色关系的数据行级权限控制​​!

相关推荐
十五年专注C++开发6 小时前
Oat++: 一个轻量级、高性能、零依赖的 C++ Web 框架
开发语言·c++·web服务·oatpp
陈天伟教授6 小时前
心电心音同步分析-案例:原型设计一
开发语言·人工智能·python·语言模型·架构
Allen_LVyingbo6 小时前
量子计算Dirac Notation基本教学—从零基础到读懂量子信息论文(下)
开发语言·人工智能·python·数学建模·量子计算
wjs20246 小时前
Ruby File 类和方法
开发语言
xyq20246 小时前
API 类别 - UI 核心
开发语言
Dxy12393102166 小时前
Python路径算法简介
开发语言·python·算法
文慧的科技江湖6 小时前
光储充协同的终极闭环:用SpringCloud微服务打造“发-储-充-用“智能能源网络 - 慧知开源充电桩管理平台
java·开发语言·spring cloud·微服务·能源·充电桩开源平台·慧知重卡开源充电桩平台
東雪木6 小时前
Java学习——内部类(成员内部类、静态内部类、局部内部类、匿名内部类)的用法与底层实现
java·开发语言·学习·java面试
昵称暂无16 小时前
通过 C# 复制 Word 文档、指定段落、指定节
开发语言·c#·word
满满和米兜6 小时前
【Java基础】-I/O-字符流
java·开发语言·python