当前位置: 移动技术网 > IT编程>开发语言>.net > 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(26)-权限管理系统-分配角色给用户

构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(26)-权限管理系统-分配角色给用户

2018年02月18日  | 移动技术网IT编程  | 我要评论

半世王爷一世情,糖果消消看,幻梦变身曲

角色权限设置授权给他

 

在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 [AppDB]

GO

/****** Object:  StoredProcedure [dbo].[P_Sys_GetRoleByUserId]    Script Date: 02/21/2014 11:17:38 ******/

SET ANSI_NULLS ON

GO

SET QUOTED_IDENTIFIER ON

GO

Create proc [dbo].[P_Sys_GetRoleByUserId]

@UserId varchar(50)

as

begin

--读取用户所包含的角色

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 desc

end 

复制代码

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

 

 

复制代码

Create PROCEDURE [dbo].[P_Sys_UpdateSysRoleSysUser]

@roleId varchar(50),@userId varchar(50)

AS

--更新角色用户中间关系表

BEGIN

    insert into SysRoleSysUser(SysRoleId,SysUserId)

        values(@roleId,@userId)

END

复制代码

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

可以参考逻辑做成程序。

 

SysBLL添加以下方法

 

复制代码

 public IQueryable<P_Sys_GetRoleByUserId_Result> GetRoleByUserId(ref GridPager pager, string userId)

        {

            IQueryable<P_Sys_GetRoleByUserId_Result> 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<P_Sys_GetRoleByUserId_Result> 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();

            }

        }

复制代码

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

 

接下来填写GetRoleByUser视图代码

 

 

复制代码

@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>();

}

}

 

<p class="mvctool bgb">

@Html.ToolButton("btnSave", "icon-save", "保存", perm, "Create", true)

</p>

<p class="pd3">

<table id="UserList"></table>

</p>

@*Jqgrid*@

<script type="text/javascript">

    $(function () {

 

        $('#UserList').datagrid({

            url: '/SysUser/GetRoleListByUser?userId=@(ViewBag.UserId)',

            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: 'Name', title: '角色名称', width: 120 },

                { field: 'Description', title: '说明', width: 80},

                { field: 'Flag', title: '是否分配', width: 80, editor: { type: 'checkbox', options: { on: '1', off: '0' } }}

            ]],

            onLoadSuccess: function () {

                var rows = $("#UserList").datagrid("getRows");

                for (var i = 0; i < rows.length; i++) {

                    //获取每一行的数据

                    $('#UserList').datagrid('beginEdit', i);

                }

            }

        });

    });

</script>

 

@*operation*@

<script type="text/javascript">

    $(function () {

        $("#btnSave").click(function () {

 

            var rows = $("#UserList").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 roleIds = data.join();

            //提交数据库

            $.post("/SysUser/UpdateUserRoleByUserId", { userId: '@(ViewBag.UserId)', roleIds: roleIds },

             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>

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网