• mvc中菜单项的增、删、改权限的其中一种解决方案


    我一直都比较关注 功能项增、删、改查权限的解决方案  也看过园子里一些园友的解决方案  可是一直都没看到我期待的解决方法(也许是我没看见) 

    前端时间看到一边扩展的文章 顿时豁然开朗 想出了一种解决方案

    功能描述 

       如:菜单管理  路径为:/Back/Menu            我需要为这个页面根据角色或个人等设置 增、删、改权限  下面就以角色为例(需判断多个取并集)

    我的解决方案:

       首先用一个关系表 保存菜单 

      菜单ID  角色ID  拥有权限

      1         1           ADD;EDIT;DEL

      2         1            ADD

      3         1            DEL 

    角色ID为1的用户拥有 三个菜单项的权限  (权限是根据一种约定设定  ADD为增加 EDIT为编辑  DEL为修改   可根据自己喜好设定

    扩展Html.ActionLink 方法 如:

    using System.Web.Mvc.Html;
    using System.Web.Security;
    using IService;
    using Models;
    using System.Collections.Generic;
    using yujiajunMvc;
    using System.Linq;
    
    namespace System.Web.Mvc
    {
        public static class HtmlExtensions
        {
            /// <summary>
            /// 判断权限连接
            /// </summary>
            /// <param name="htmlHelper"></param>
            /// <param name="linkText">显示的文字</param>
            /// <param name="operate">当前什么操作 ADD添加 EDIT编辑 DEL删除</param>
            /// <returns></returns>
            public static MvcHtmlString ActionLinks(this HtmlHelper htmlHelper, string linkText, string actionName, string controllName, object routeValues, object htmlAttributes, string operate)
            {
                HttpCookie cookie = HttpContext.Current.Request.Cookies["operateItem"];//在登录时保存用户权限 在此处获取该用户的权限
                if (cookie == null || string.IsNullOrEmpty(operate))
                    return MvcHtmlString.Empty;
                string path = HttpContext.Current.Request.RawUrl.ToLower();// 当前页面路径
                List<string> list = DESEncrypt.Decrypt(cookie.Value).Split(',').ToList();//解密转为字符串 取得当前用户的功能权限此处我设置为 /Back/Menu/_ADD;EDIT,/Back/UserList/_EDIT;DEL 以此类推  此处注意mvc中路径有些区别 如 /Back/Menu /Back/Menu/  等都是访问同一页面 所以设置约定是需注意此处变化
            var limit = list.FirstOrDefault(a => a.Contains(path));//如果当前页面在 权限能找到 if (limit != null) if (limit.Contains(operate)) //并且拥有传递进来的权限 此处需和自己的约定一直 return htmlHelper.ActionLink(linkText, actionName, controllName, routeValues, htmlAttributes); //返回连接 return MvcHtmlString.Empty;//没有权限返回为空 } public static MvcHtmlString ActionLinkEmpty(this HtmlHelper htmlHelper, string linkText, string operate, string property = null) { HttpCookie cookie = HttpContext.Current.Request.Cookies["operateItem"];//获取该用户的权限 if (cookie == null || string.IsNullOrEmpty(operate)) return MvcHtmlString.Empty; string path = HttpContext.Current.Request.RawUrl.ToLower();//当前页面路径 List<string> list = DESEncrypt.Decrypt(cookie.Value).Split(',').ToList();//解密转为字符串 var limit = list.FirstOrDefault(a => a.Contains(path)); if (limit != null) if (limit.Contains(operate)) return MvcHtmlString.Create(string.Format("<a href=\"javascript:void(0)\" id=\"{0}\" class=\"{1}\" {2}>{3}</a>", operate, operate, property, linkText)); return MvcHtmlString.Empty; } } }

      前台页面调用

    @Html.ActionLinks("添 加","UserADD","Items",null,null,"ADD")

    这样就实现了权限判断  

    此处还存在一个问题 一直没想到好的解决方案  希望园友们能提供好的解决方案

    当用户直接在浏览器输入时  在子页面不好做权限判断  上面也提到了次问题 

    /Back/Menu/ADD    /Back/Menu/ADD/   /Back/Menu/ADD/1
    等都是访问同一页面 所以不好根据路径判断
  • 相关阅读:
    解决面试题的思路--5
    剑指offer例题分享--4
    剑指offer--3
    剑指offer--2
    【数据结构】5.2 二叉搜索树的创建查找以及插入操作
    【数据结构】5.1 顺序表的查找以及二分查找的实现
    【数据结构】4.1图的创建及DFS深度遍历(不完善)
    【密码学】RSA加密 kotlin实现方法(支持任意字节长度)
    【数据结构】3-2哈夫曼树的实现(数组实现)以及哈夫曼编码
    【密码学】公钥密码体制概述
  • 原文地址:https://www.cnblogs.com/yujiajun/p/operate.html
Copyright © 2020-2023  润新知