博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(26)-权限管理系统-分配角色给用户...
阅读量:5285 次
发布时间:2019-06-14

本文共 5745 字,大约阅读时间需要 19 分钟。

由于之前做了将权限赋给角色,还需要做将角色组赋给用户,和将用户赋给角色组,一个用户可以拥有多个角色组,一个角色组包含多个用户,打开模块管理,添加一个分配的操作码

并在

角色权限设置授权给他

在SysUser的Index添加以下按钮

@Html.ToolButton("btnAllot", "icon-share", "分配角色", perm, "Allot", true)

我们要弹出所有角色的选择窗口来勾选后保存。这个大家应该想到了,所以先设置弹出界面的视图,我命名为GetRoleByUser

所以在SysUser添加以下3个方法

#region 设置用户角色        [SupportFilter(ActionName = "Allot")]        public ActionResult GetRoleByUser(string userId)        {            ViewBag.UserId = userId;            ViewBag.Perm = GetPermission();            return View();        }        [SupportFilter(ActionName = "Allot")]        public JsonResult GetRoleListByUser(GridPager pager, string userId)        {            if (string.IsNullOrWhiteSpace(userId))                return Json(0);            var userList = userBLL.GetRoleByUserId(ref pager,userId);            var jsonData = new            {                total = pager.totalRows,                rows = (                    from r in userList                    select new SysRoleModel()                    {                      Id= r.Id,                      Name= r.Name,                      Description = r.Description,                      Flag = r.flag=="0"?"0":"1",                    }                ).ToArray()            };            return Json(jsonData);        }        #endregion        [SupportFilter(ActionName = "Save")]        public JsonResult UpdateUserRoleByUserId(string userId, string roleIds)        {            string[] arr = roleIds.Split(',');            if (userBLL.UpdateSysRoleSysUser(userId, arr))            {                LogHandler.WriteServiceLog(GetUserId(), "Ids:" + roleIds, "成功", "分配角色", "用户设置");                return Json(JsonHandler.CreateMessage(1, Suggestion.SetSucceed), JsonRequestBehavior.AllowGet);            }            else            {                string ErrorCol = errors.Error;                LogHandler.WriteServiceLog(GetUserId(), "Ids:" + roleIds, "失败", "分配角色", "用户设置");                return Json(JsonHandler.CreateMessage(0, Suggestion.SetFail), JsonRequestBehavior.AllowGet);            }                    }

GetRoleByUser为弹出视图

GetRoleListByUser为根据选择的用户获取角色并让已经分配的角色呈现选择状态 (存储过程实现)

USE [DB]GO/****** Object:  StoredProcedure [dbo].[P_Sys_GetRoleByUserId]    Script Date: 02/21/2014 11:17:38 ******/SET ANSI_NULLS ONGOSET QUOTED_IDENTIFIER ONGOCreate proc [dbo].[P_Sys_GetRoleByUserId]@UserId varchar(50)asbegin--读取用户所包含的角色select a.*,ISNULL(b.SysUserId,0) as flag from SysRole a left join    SysRoleSysUser b     on a.Id = b.SysRoleId    and b.SysUserId = @UserId    order by b.SysUserId descend P_Sys_GetRoleByUserId
P_Sys_GetRoleByUserI

UpdateUserRoleByUserId更新选择的后的情况(存储过程实现)

Create PROCEDURE [dbo].[P_Sys_UpdateSysRoleSysUser]@roleId varchar(50),@userId varchar(50)AS--更新角色用户中间关系表BEGIN    insert into SysRoleSysUser(SysRoleId,SysUserId)        values(@roleId,@userId)ENDP_Sys_UpdateSysRoleSysUser
P_Sys_UpdateSysRoleSysUser

存储过程语句简短,如果做成linq也好的,但这并不多变,所以我写成了存储过程。

可以参考逻辑做成程序。

SysBLL添加以下方法

public IQueryable
GetRoleByUserId(ref GridPager pager, string userId) { IQueryable
queryData = sysUserRepository.GetRoleByUserId(db, userId); pager.totalRows = queryData.Count(); queryData = sysUserRepository.GetRoleByUserId(db, userId); return queryData.Skip((pager.page - 1) * pager.rows).Take(pager.rows); } public bool UpdateSysRoleSysUser(string userId, string[] roleIds) { try { sysUserRepository.UpdateSysRoleSysUser(userId, roleIds); return true; } catch (Exception ex) { ExceptionHander.WriteException(ex); return false; } }

SysRepository添加以下对应方法

public IQueryable
GetRoleByUserId(DBContainer db, string userId) { return db.P_Sys_GetRoleByUserId(userId).AsQueryable(); } public void UpdateSysRoleSysUser(string userId, string[] roleIds) { using (DBContainer db = new DBContainer()) { db.P_Sys_DeleteSysRoleSysUserByUserId(userId); foreach (string roleid in roleIds) { if (!string.IsNullOrWhiteSpace(roleid)) { db.P_Sys_UpdateSysRoleSysUser(roleid,userId); } } db.SaveChanges(); } }

DAL层还用到了一个存储过程为更新角色用户中间关系表,前删除关联

Create PROCEDURE [dbo].[P_Sys_DeleteSysRoleSysUserByUserId]@userId varchar(50)AS--更新角色用户中间关系表,前删除关联BEGIN    delete SysRoleSysUser where @userIdEND

让后自行添加接口方法即可

接下来填写GetRoleByUser视图代码

@using App.Admin;@using App.Common;@using App.Models.Sys;@{    ViewBag.Title = "设置用户包含的角色";    Layout = "~/Views/Shared/_Index_LayoutEdit.cshtml";List
perm = (List
)ViewBag.Perm;if (perm == null){ perm = new List
();}}
@Html.ToolButton("btnSave", "icon-save", "保存", perm, "Create", true)
@*Jqgrid*@
@*operation*@
View Code

 

在index添加分配的js代码

$("#btnAllot").click(function () {           var row = $('#List').datagrid('getSelected');           if (row != null) {                              $("#modalwindow").html("");               $("#modalwindow").window({ title: '分配角色', width: 720, height: 400, iconCls: 'icon-edit' }).window('open');           } else { $.messageBox5s('提示', '@Suggestion.PlaseChooseToOperatingRecords'); }        });

 

这时可以显示一下界面了

添加多几个角色测试一下。

给大家说一下,大家不要再问我开源不了,不会再发布源码包,现源码发布到14讲(14讲包含了素材js等通用元素),数据库是17讲,在群里提供下载,之后的文章都是有贴代码的,而且易懂,可以组成我发布的系统完整版,源码如下:vs2013下的源码:

转载于:https://www.cnblogs.com/zhangjunwei87/p/4691256.html

你可能感兴趣的文章
熟悉项目需求,要知道产品增删修改了哪些内容,才会更快更准确的在该项目入手。...
查看>>
JavaScript 变量
查看>>
java实用类
查看>>
smarty模板自定义变量
查看>>
研究称90%的癌症由非健康生活习惯导致
查看>>
命令行启动Win7系统操作部分功能
查看>>
排序sort (一)
查看>>
Parrot虚拟机
查看>>
Teamcenter10 step-by-step installation in Linux env-Oracle Server Patch
查看>>
Struts2学习(三)
查看>>
Callable和Runnable和FutureTask
查看>>
GitHub 多人协作开发 三种方式:
查看>>
文本域添加编辑器
查看>>
Yum安装MySQL以及相关目录路径和修改目录
查看>>
java获取hostIp和hostName
查看>>
关于web服务器和数据库的各种说法(搜集到的)
查看>>
C# Stream 和 byte[] 之间的转换
查看>>
OMG: daily scrum nine
查看>>
redis与spring结合错误情况
查看>>
第六章 字节码执行方式--解释执行和JIT
查看>>