ASP.NET MVC实现权限管理以及权限分配「建议收藏」

ASP.NET MVC实现权限管理以及权限分配「建议收藏」权限管理与分配至少要有三张表然而往往难住我们的并不是数据库的设计而是后台的实现 //查询用户所具有的权限    publicListGetprenisson(intuserid){      ptestEntitiespst=newptestEntities();          stringsql

大家好,又见面了,我是你们的朋友全栈君。

权限管理与分配至少要有三张表

  • ASP.NET MVC实现权限管理以及权限分配「建议收藏」

然而 往往难住我们的并不是数据库的设计而是后台的实现

 //查询用户所具有的权限
        public List<prenisson> Getprenisson(int userid) {

            ptestEntities pst = new ptestEntities();
      
            string sql = “select * from  prenisson  where Id in (select   prenissonId from  prenisson_Users where UsersId=@userid)”;

            List<prenisson> plist = pst.Database.SqlQuery<prenisson>(sql, new SqlParameter(“userid”, userid)).ToList();

          return plist;

}


控制器拿到用户id 查询用户所具有的权限


        public JsonResult GetUsero( int userid) {

            UserDAL ud = new UserDAL();

            List<prenisson> plists = ud.Getprenisson(userid);

            return Json(plists);
        
        }
   从视图里获取数据库的数据库  解析父级与子级


ASP.NET MVC实现权限管理以及权限分配「建议收藏」

   //查询该项目中所有的权限
        public List<prenisson> GetPsson() 
        {

            ptestEntities pst = new ptestEntities();
         List<prenisson> lpist = pst.prenisson.ToList();

           return lpist;
        }
        //保存分配的权限
        public bool SveGet(int userid, List<string> premissid)
        { 
        //先删除原来的权限
            ptestEntities pst = new ptestEntities();
            pst.Database.ExecuteSqlCommand(“delete prenisson_Users where UsersId=” + userid + “”);

 public void Svopon(int userid,string rempremison) {

            UserDAL ud = new UserDAL();

            //逗号分隔
            List<string> listint = rempremison.Split(‘,’).ToList();
            listint.RemoveAt(listint.Count()-1);

            bool isuccess = ud.SveGet(userid, listint);
        }

做一个下拉列表框

        //下拉列表框改变事件
        $(“#user_sel”).change(function () {

            var userid = $(this).val();
           
            //发送一个AJaX请求  得到选择用户的权限
            $.ajax({

                url: ‘/Preniss/GetUsero’,
                type: ‘post’,
                data: { userid: userid },
                success: function (reuslt) {

                    console.log(reuslt);
                    //清空复选框的选中
                    $(“#poon_check input[type=’checkbox’]”).prop(“checked”,false);
                    $(“#poon_check input[type=’checkbox’]”).parent().removeClass(“checked”);
                    //读取用户权限的id
                    // 找到所有的复选框
                    $.each(reuslt, function (index, item) {

                                   
                        $(“#poon_check input[type=’checkbox’][value=” + item.Id + “]”).prop(“checked”, true);
                 
                        $(“#poon_check input[type=’checkbox’][value=” + item.Id + “]”).parent().addClass(“checked”);
                        
                    });
                  
                }
            });
        });
        //给保存添加一个点击事件
        $(“#sub_but”).click(function () {

            //拿到用户id
            var userid = $(“#user_sel”).val();
            //拿到权限id
            var premiood = “”;
            //找到所有选中的复选框0
            $(“#poon_check input[type=’checkbox’]:checked”).each(function (index, item) {

                premiood+=$(item).val()+”,”;
            });
            //添加到数据库实现保存
            $.post(‘/Preniss/Svopon’, { userid: userid, rempremison: premiood }, function () {

                alert(“添加成功”);
            });
        });

勾选出用户,用户原有的权限已被勾选。只需要在下方权限中勾选中  点击授权  方可被授权。

ASP.NET MVC实现权限管理以及权限分配「建议收藏」





  

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/162903.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • 基于Html5的移动端APP开发框架「建议收藏」

    基于Html5的移动端APP开发框架「建议收藏」快速增长的APP应用软件市场,以及智能手机的普及,手机应用:Native(原生)APP快速占领了APP市场,成为了APP开发的主流,但其平台的不通用性,开发成本高,多版本开发等问题,一直困扰着专业APP开发企业,和APP服务提供商。安卓和IOS的操作方式,开发模式,界面UI显示方面的差别,也使得原生APP的不同版本体验有很大的区别,光是做兼容性调测,都要花费开发企业不少的时间。近年来,另一种

  • platform_device与platform_driver

    platform_device与platform_driver

  • vagrant 登录不了

    vagrant 登录不了

  • 电力系统104规约帧报文解析

    电力系统104规约帧报文解析最近被调到电力物联网的项目组,之前一直在做移动终端的我现在在这个项目中得要重新学起了。。~_~!1.电力系统常见概念首先介绍一份ppt:https://wenku.baidu.com/view/557ceb87be23482fb5da4c84.html看着挺好。。。这边文章主要是解释一些电力系统开发中比较常见的概念,也是给自己做个笔记~~~~~~电力系统远动(powersys…

  • 设置pip源

    设置pip源我使用pip镜像源有两种方式:一、下载最后加上-ihttp://pypi.doubanio.com/simple–trusted-hostpypi.doubanio.com缺点是每次下载都要粘贴一次,略为麻烦。二、直接更改pip的默认下载源打开这条路径(一般没有pip文件夹,需要自己创建)C:\Users\gaz\pip新建一个txt文件内容为:[global]index-url=https://pypi.douban.com/simple/…

  • 单片机控制步进电机正反转c语言程序,单片机控制步进电机1步10步100步正反转…

    单片机控制步进电机正反转c语言程序,单片机控制步进电机1步10步100步正反转…原标题:单片机控制步进电机1步10步100步正反转一,程序设计方案的构想:1)的控制原理步进电机是将电脉冲信号转变为角位移或线位移的开环控制元件.在非超载的情况下,电机的转速,停止的位置只取决于脉冲信号的频率和脉冲数,而不受负载变化的影响.即给电机加一个信号,电机则转过一个步距角.这一线形关系的存在,加上步进电机只有周期性的误差而无积累误差等特点,使得在线速度,位置等控制领域用步进电机来控制变的…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号