ASP.NET MVC5+EF6+EasyUI 后台管理系统(27)-权限管理系统-分配用户给角色
时间:2022-04-22
本文章向大家介绍ASP.NET MVC5+EF6+EasyUI 后台管理系统(27)-权限管理系统-分配用户给角色,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
分配用户给角色,跟分配角色给用户操作是基本一致的。
打开模块维护,展开SysRole模块添加一个操作码,并赋予权限
设置好之后将权限授权给管理员,在SysRole的index添加操作码与js事件
@Html.ToolButton("btnAllot", "icon-share", "分配用户", perm, "Allot", true)
$("#btnAllot").click(function () {
var row = $('#List').datagrid('getSelected');
if (row != null) {
$("#modalwindow").html("<iframe width='100%' height='100%' scrolling='no' frameborder='0' src='/SysRole/GetUserByRole?roleId=" + row.Id + "&Ieguid=" + GetGuid() + "'></iframe>");
$("#modalwindow").window({ title: '分配用户', width: 720, height: 400, iconCls: 'icon-edit' }).window('open');
} else { $.messageBox5s('提示', '请选择一个需要分配用户的角色'); }
});
由于和26讲基本一致,只是User改成Role,Role改成User 在SysRoleController添加以下3个方法
#region 设置角色用户
[SupportFilter(ActionName = "Allot")]
public ActionResult GetUserByRole(string roleId)
{
ViewBag.RoleId = roleId;
ViewBag.Perm = GetPermission();
return View();
}
[SupportFilter(ActionName="Allot")]
public JsonResult GetUserListByRole(GridPager pager,string roleId)
{
if (string.IsNullOrWhiteSpace(roleId))
return Json(0);
var userList = m_BLL.GetUserByRoleId(ref pager, roleId);
var jsonData = new
{
total = pager.totalRows,
rows = (
from r in userList
select new SysUserModel()
{
Id = r.Id,
UserName = r.UserName,
TrueName = r.TrueName,
Flag = r.flag == "0" ? "0" : "1",
}
).ToArray()
};
return Json(jsonData);
}
#endregion
[SupportFilter(ActionName = "Save")]
public JsonResult UpdateUserRoleByRoleId(string roleId,string userIds)
{
string[] arr = userIds.Split(',');
if (m_BLL.UpdateSysRoleSysUser(roleId,arr))
{
LogHandler.WriteServiceLog(GetUserId(), "Ids:" + arr, "成功", "分配用户", "角色设置");
return Json(JsonHandler.CreateMessage(1, Suggestion.SetSucceed), JsonRequestBehavior.AllowGet);
}
else
{
string ErrorCol = errors.Error;
LogHandler.WriteServiceLog(GetUserId(), "Ids:" + arr, "失败", "分配用户", "角色设置");
return Json(JsonHandler.CreateMessage(0, Suggestion.SetFail), JsonRequestBehavior.AllowGet);
}
}
GetUserByRole为弹出视图
GetUserListByRole为根据选择的用户获取角色并让已经分配的角色呈现选择状态 (存储过程实现)
Create proc [dbo].[P_Sys_GetUserByRoleId]
@RoleId varchar(50)
as
begin
--读取角色所包含的用户
select a.*,ISNULL(b.SysUserId,0) as flag from SysUser a left join
SysRoleSysUser b on a.Id=b.SysUserId
and b.SysRoleId=@RoleId
order by b.SysRoleId desc
end
UpdateUserRoleByRoleId更新选择的后的情况(存储过程实现)
Create PROCEDURE [dbo].[P_Sys_UpdateSysRoleSysUser]
@roleId varchar(50),@userId varchar(50)
AS
--更新角色用户中间关系表
BEGIN
insert into SysRoleSysUser(SysRoleId,SysUserId)
values(@roleId,@userId)
END
添加BLL方法
/// <summary>
/// 获取角色对应的所有用户
/// </summary>
/// <param name="roleId">角色id</param>
/// <returns></returns>
public string GetRefSysUser(string roleId)
{
string UserName = "";
var userList = m_Rep.GetRefSysUser(db, roleId);
if (userList != null)
{
foreach (var user in userList)
{
UserName += "[" + user.UserName + "] ";
}
}
return UserName;
}
public IQueryable<P_Sys_GetUserByRoleId_Result> GetUserByRoleId(ref GridPager pager, string roleId)
{
IQueryable<P_Sys_GetUserByRoleId_Result> queryData = m_Rep.GetUserByRoleId(db, roleId);
pager.totalRows = queryData.Count();
queryData = m_Rep.GetUserByRoleId(db, roleId);
return queryData.Skip((pager.page - 1) * pager.rows).Take(pager.rows);
}
public bool UpdateSysRoleSysUser(string roleId, string[] userIds)
{
try
{
m_Rep.UpdateSysRoleSysUser(roleId, userIds);
return true;
}
catch (Exception ex)
{
ExceptionHander.WriteException(ex);
return false;
}
}
添加DAL方法
public IQueryable<SysUser> GetRefSysUser(DBContainer db, string id)
{
if (!string.IsNullOrEmpty(id))
{
return from m in db.SysRole
from f in m.SysUser
where m.Id == id
select f;
}
return null;
}
public IQueryable<P_Sys_GetUserByRoleId_Result> GetUserByRoleId(DBContainer db, string roleId)
{
return db.P_Sys_GetUserByRoleId(roleId).AsQueryable();
}
public void UpdateSysRoleSysUser(string roleId,string[] userIds)
{
using(DBContainer db = new DBContainer())
{
db.P_Sys_DeleteSysRoleSysUserByRoleId(roleId);
foreach (string userid in userIds)
{
if (!string.IsNullOrWhiteSpace(userid))
{
db.P_Sys_UpdateSysRoleSysUser(roleId, userid);
}
}
db.SaveChanges();
}
}
新角色用户中间关系表,前删除关联
Create PROCEDURE [dbo].[P_Sys_DeleteSysRoleSysUserByRoleId]
@roleId varchar(50)
AS
--更新角色用户中间关系表,前删除关联
BEGIN
delete SysRoleSysUser where SysRoleId=@roleId
END
自行添加BLL和DAL的接口方法 添加GetUserByRole.cshtml视图
@using App.Admin;
@using App.Common;
@using App.Models.Sys;
@{
ViewBag.Title = "设置角色包含的用户";
Layout = "~/Views/Shared/_Index_LayoutEdit.cshtml";
List<permModel> perm = (List<permModel>)ViewBag.Perm;
if (perm == null)
{
perm = new List<permModel>();
}
}
<div class="mvctool bgb">
@Html.ToolButton("btnSave", "icon-save", "保存", perm, "Create", true)
</div>
<div class="pd3">
<table id="RoleList"></table>
</div>
@*Jqgrid*@
<script type="text/javascript">
$(function () {
$('#RoleList').datagrid({
url: '/SysRole/GetUserListByRole?roleId=@(ViewBag.RoleId)',
width: SetGridWidthSub(6),
methord: 'post',
height: SetGridHeightSub(41),
fitColumns: true,
sortName: 'Id',
sortOrder: 'desc',
idField: 'Id',
pageSize: 12,
pageList: [12, 20, 30, 40, 50],
pagination: true,
striped: true, //奇偶行是否区分
singleSelect: true,//单选模式
columns: [[
{ field: 'Id', title: 'ID', width: 80, hidden: true },
{ field: 'UserName', title: '用户名', width: 120 },
{ field: 'TrueName', title: '姓名', width: 80 },
{ field: 'Flag', title: '是否分配', width: 80, editor: { type: 'checkbox', options: { on: '1', off: '0' } } }
]],
onLoadSuccess: function () {
var rows = $("#RoleList").datagrid("getRows");
for (var i = 0; i < rows.length; i++) {
//获取每一行的数据
$('#RoleList').datagrid('beginEdit', i);
}
}
});
});
</script>
@*operation*@
<script type="text/javascript">
$(function () {
$("#btnSave").click(function () {
var rows = $("#RoleList").datagrid("getRows"); //这段代码是获取当前页的所有行。
var data = new Array();
for (var i = 0; i < rows.length; i++) {
var setFlag = $("td[field='Flag'] input").eq(i).prop("checked");
if (setFlag)//判断是否有作修改
{
data.push(rows[i].Id);
}
}
var userIds = data.join();
//提交数据库
$.post("/SysRole/UpdateUserRoleByRoleId", { roleId: '@(ViewBag.RoleId)', userIds: userIds },
function (data) {
if (data.type == 1) {
window.parent.frameReturnByMes(data.message);
window.parent.frameReturnByReload(true);
window.parent.frameReturnByClose()
}
else {
window.parent.frameReturnByMes(data.message);
}
}, "json");
});
});
</script>
理论上效果都会出来。
- 局部打印插件 jquery.PrintArea.js
- FluorineFx应用中“页面长时间不动”导致无法连接的解决办法
- Mysql主从同步(1)-主从/主主环境部署梳理
- mysql主从同步(3)-percona-toolkit工具(数据一致性监测、延迟监控)使用梳理
- 网站压力测试软件WebBench以及压测Jexus
- Gershon Dublon & Nan Zhao:用传感器网络感知世界
- 即日起珠海可用微信乘公交,腾讯乘车码助力智慧城市建设
- 利用mk-table-checksum监测Mysql主从数据一致性操作记录
- mysql主从同步(4)-Slave延迟状态监控
- 浏览器窗口尺寸改变时的图片自动重新定位
- Mongodb主从复制/ 副本集/分片集群介绍
- Paul-Adrien Menez:互联网与抵制食物浪费的故事
- DRBD详细解说及配置过程记录
- Servant:基于Web的IIS管理工具
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Spark SQL解析查询parquet格式Hive表获取分区字段和查询条件
- Apache Hive
- SAUI-关于input滚动问题
- 学好Spark必须要掌握的Scala技术点
- EF Linq中的左连接Left Join查询
- dotnet 删除自身程序的方法
- Roslyn 读取 PackageReference 的版本号和内容
- Web开发中的时区问题
- 编写代码生成器的一些问题与思考
- 和小曼一起走到MySQL行的尽头
- 明亮解我“工厂模式无用”之惑
- 「源码分析」— 为什么枚举是单例模式的最佳方法
- 如何记忆 Spring Bean 的生命周期
- 系统学习Stream
- Java回调的四种写法(反射、直接调用、接口调用、Lamda表达式)