zoukankan      html  css  js  c++  java
  • MVC巧用枚举做权限管理

    用户数据表,每个用户有一个或者多个权限,用户表如下

    userid,roleid,username等

    权限枚举如下:

    public class CustomEnum
        {
            [Flags]
            /// <summary>
            /// 用户角色枚举
            /// </summary>
            public enum UserRole
            {
                /// <summary>
                /// 游客
                /// </summary>
                Visitor = 1,
                /// <summary>
                /// 学生
                /// </summary>
                Student = 2,
                /// <summary>
                /// 老师
                /// </summary>
                ///
                Teacher = 4,
                /// <summary>
                /// 家长
                /// </summary>
                Parents = 8,
                /// <summary>
                /// 加盟商
                /// </summary>
                Agents = 16
            }
        }

    为以下对象权限对象赋值

      /// <summary>
            /// 用户角色
            /// </summary>
            public static CustomEnum.UserRole UserRole
            {
                get
                {
                    if (!string.IsNullOrEmpty(SessionAction.ReadSession("xxb_WebUserRole")))
                    {
                        return (CustomEnum.UserRole)Enum.Parse(typeof(CustomEnum.UserRole), SessionAction.ReadSession("xxb_WebUserRole"));
                      }
                    else
                    {
                        return CustomEnum.UserRole.Visitor;
                    }
                }
                set
                {
                    System.Web.HttpContext.Current.Session["xxb_WebUserRole"] = (CustomEnum.UserRole)Enum.Parse(typeof(CustomEnum.UserRole), value.ToString());

                }
            }

    用以下语句判断是否属于某种权限,并进行某种操作

     if (WebSession.UserRole == CustomEnum.UserRole.Visitor) //如果是普通游客 
                    {
                        //跳转到登陆页面
                        filterContext.Result = new RedirectResult("/User/LogOn?ReturnUrl=" + filterContext.HttpContext.Request.Url);
                    }
                    else
                    {
                        //跳转到权限提醒页面
                        filterContext.Result = new RedirectResult("/Home/Role?ReturnUrl=" + filterContext.HttpContext.Request.Url);
                    }

  • 相关阅读:
    RabbitMQ的应用场景以及基本原理介绍
    spring 读取配置文件,将值注入到静态字段
    单元测试不依赖于容器,任何依赖容器的测试在单元测试中都行不通(切记,切记)
    在 KVM 上安装 Win7 虚拟机
    识别 Linux上的设备(磁盘)类型
    云与备份之(1):VMware虚机备份和恢复
    理解 OpenStack + Ceph (9): Ceph 的size/min_size/choose/chooseleaf/scrubbing/repair 等概念
    OpenStack 企业私有云的若干需求(10):OpenStack 的前景和钱景
    OpenStack 企业私有云的若干需求(9): 云管理平台 CMP
    理解 OpenStack + Ceph (8): 基本的 Ceph 性能测试工具和方法
  • 原文地址:https://www.cnblogs.com/lori/p/2196638.html
Copyright © 2011-2022 走看看