系列目录

分配用户给角色,跟分配角色给用户操作是基本一致的。

打开模块维护,展开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: , height: , 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();
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 == "" ? "" : "",
}
).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(, Suggestion.SetSucceed), JsonRequestBehavior.AllowGet);
}
else
{
string ErrorCol = errors.Error;
LogHandler.WriteServiceLog(GetUserId(), "Ids:" + arr, "失败", "分配用户", "角色设置");
return Json(JsonHandler.CreateMessage(, Suggestion.SetFail), JsonRequestBehavior.AllowGet);
} }

GetUserByRole为弹出视图

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

Create proc [dbo].[P_Sys_GetUserByRoleId]
@RoleId varchar()
as
begin
--读取角色所包含的用户
select a.*,ISNULL(b.SysUserId,) as flag from SysUser a left join
SysRoleSysUser b on a.Id=b.SysUserId
and b.SysRoleId=@RoleId
order by b.SysRoleId desc
end

P_Sys_GetUserByRoleId

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

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

P_Sys_UpdateSysRoleSysUser

添加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 - ) * 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;
}
}

BLL

添加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();
}
}

DAL

新角色用户中间关系表,前删除关联

Create PROCEDURE [dbo].[P_Sys_DeleteSysRoleSysUserByRoleId]
@roleId varchar()
AS
--更新角色用户中间关系表,前删除关联
BEGIN
delete SysRoleSysUser where SysRoleId=@roleId
END

P_Sys_DeleteSysRoleSysUserByRoleId

自行添加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(),
methord: 'post',
height: SetGridHeightSub(),
fitColumns: true,
sortName: 'Id',
sortOrder: 'desc',
idField: 'Id',
pageSize: ,
pageList: [, , , , ],
pagination: true,
striped: true, //奇偶行是否区分
singleSelect: true,//单选模式
columns: [[
{ field: 'Id', title: 'ID', width: , hidden: true },
{ field: 'UserName', title: '用户名', width: },
{ field: 'TrueName', title: '姓名', width: },
{ field: 'Flag', title: '是否分配', width: , editor: { type: 'checkbox', options: { on: '', off: '' } } }
]],
onLoadSuccess: function () {
var rows = $("#RoleList").datagrid("getRows");
for (var i = ; 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 = ; 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 == ) {
window.parent.frameReturnByMes(data.message);
window.parent.frameReturnByReload(true);
window.parent.frameReturnByClose()
}
else {
window.parent.frameReturnByMes(data.message);
}
}, "json");
}); });
</script>

GetUserByRole

理论上效果都会出来。

ASP.NET MVC5+EF6+EasyUI 后台管理系统(27)-权限管理系统-分配用户给角色的更多相关文章

  1. ASP.NET MVC5+EF6+EasyUI 后台管理系统(1)-前言与目录(持续更新中...)

    开发工具:VS2015(2012以上)+SQL2008R2以上数据库  您可以有偿获取一份最新源码联系QQ:729994997 价格 666RMB  升级后界面效果如下: 任务调度系统界面 http: ...

  2. ASP.NET MVC5+EF6+EasyUI 后台管理系统(1)-前言与目录(转)

    开发工具:VS2015(2012以上)+SQL2008R2以上数据库 您可以有偿获取一份最新源码联系QQ:729994997 价格 666RMB 升级后界面效果如下: 日程管理   http://ww ...

  3. ASP.NET MVC5+EF6+EasyUI 后台管理系统(63)-Excel导入和导出-自定义表模导入

    系列目录 前言 上一节使用了LinqToExcel和CloseXML对Excel表进行导入和导出的简单操作,大家可以跳转到上一节查看: ASP.NET MVC5+EF6+EasyUI 后台管理系统(6 ...

  4. ASP.NET MVC5+EF6+EasyUI 后台管理系统-WebApi的用法与调试

    1:ASP.NET MVC5+EF6+EasyUI 后台管理系统(1)-WebApi与Unity注入 使用Unity是为了使用我们后台的BLL和DAL层 2:ASP.NET MVC5+EF6+Easy ...

  5. ASP.NET MVC5+EF6+EasyUI 后台管理系统(51)-系统升级

    系统很久没有更新内容了,期待已久的更新在今天发布了,最近花了2个月的时间每天一点点,从原有系统 MVC4+EF5+UNITY2.X+Quartz 2.0+easyui 1.3.4无缝接入 MVC5+E ...

  6. ASP.NET MVC5+EF6+EasyUI 后台管理系统(58)-DAL层重构

    系列目录 前言:这是对本文系统一次重要的革新,很久就想要重构数据访问层了,数据访问层重复代码太多.主要集中增删该查每个模块都有,所以本次是为封装相同接口方法 如果你想了解怎么重构普通的接口DAL层请查 ...

  7. ASP.NET MVC5+EF6+EasyUI 后台管理系统(34)-文章发布系统①-简要分析

    系列目录 最新比较闲,为了学习下Android的开发构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(1)-前言与,虽然有点没有目的的学习,但还是了解了Andro ...

  8. ASP.NET MVC5+EF6+EasyUI 后台管理系统(54)-工作流设计-所有流程监控

    系列目录 先补充一个平面化登陆页面代码,自己更换喜欢的颜色背景 @using Apps.Common; @{ Layout = null; } <!DOCTYPE html> <ht ...

  9. ASP.NET MVC5+EF6+EasyUI 后台管理系统(56)-插件---单文件上传与easyui使用fancybox

    系列目录 https://yunpan.cn/cZVeSJ33XSHKZ  访问密码 0fc2 今天整合lightbox插件Fancybox1.3.4,发现1.3.4版本太老了.而目前easyui 1 ...

  10. ASP.NET MVC5+EF6+EasyUI 后台管理系统(38)-Easyui-accordion+tree漂亮的菜单导航

    系列目录 本节主要知识点是easyui 的手风琴加树结构做菜单导航 有园友抱怨原来菜单非常难看,但是基于原有树形无限级别的设计,没有办法只能已树形展示 先来看原来的效果 改变后的效果,当然我已经做好了 ...

随机推荐

  1. C++实现线程安全的单例模式

    在某些应用环境下面,一个类只允许有一个实例,这就是著名的单例模式.单例模式分为懒汉模式,跟饿汉模式两种. 首先给出饿汉模式的实现 template <class T> class sing ...

  2. Tomcat shutdown执行后无法退出进程问题排查及解决

    问题定位及排查 上周无意中调试程序在Linux上ps -ef|grep tomcat发现有许多tomcat的进程,当时因为没有影响系统运行就没当回事.而且我内心总觉得这可能是tomcat像nginx一 ...

  3. HTML5 input元素新的特性

    在HTML5中,<input>元素增加了许多新的属性.方法及控件.本文章分别对这三方面进行介绍. 目录 1. 属性 2. 方法 3. 新控件 1. 属性 <input>元素在H ...

  4. 《Django By Example》第二章 中文 翻译 (个人学习,渣翻)

    书籍出处:https://www.packtpub.com/web-development/django-example 原作者:Antonio Melé (译者注:翻译完第一章后,发现翻译第二章的速 ...

  5. 协议森林16 小美的桌号(DHCP协议)

    作者:Vamei 出处:http://www.cnblogs.com/vamei 转载请先与我联系. DHCP协议用于动态的配置电脑的网络相关参数,如主机的IP地址,路由器出口地址.DNS域名服务器地 ...

  6. 【NLP】蓦然回首:谈谈学习模型的评估系列文章(一)

    统计角度窥视模型概念 作者:白宁超 2016年7月18日17:18:43 摘要:写本文的初衷源于基于HMM模型序列标注的一个实验,实验完成之后,迫切想知道采用的序列标注模型的好坏,有哪些指标可以度量. ...

  7. peer not authenticated的终极解决方案

    一.前述 使用httpclient发起https请求时,可能会遇到如下异常: javax.net.ssl.SSLPeerUnverifiedException: peer not authentica ...

  8. 代码的坏味道(20)——过度耦合的消息链(Message Chains)

    坏味道--过度耦合的消息链(Message Chains) 特征 消息链的形式类似于:obj.getA().getB().getC(). 问题原因 如果你看到用户向一个对象请求另一个对象,然后再向后者 ...

  9. UVA-146 ID Codes

    It is 2084 and the year of Big Brother has finally arrived, albeit a century late. In order to exerc ...

  10. 纸箱堆叠 bzoj 2253

    纸箱堆叠 (1s 128MB) box [问题描述] P 工厂是一个生产纸箱的工厂.纸箱生产线在人工输入三个参数 n, p, a 之后,即可自动化生产三边边长为 (a mod P, a^2 mod p ...