Esempio n. 1
0
        /// <summary>
        /// 设置用户角色(批量设置)
        /// </summary>
        /// <param name="userIds">用户主键,多个逗号隔开</param>
        /// <param name="roleIds">角色id,多个逗号隔开</param>
        public bool SetRoleBatch(string userIds, string roleIds)
        {
            List <DriveMgr.Model.UserRole> role_addList    = new List <DriveMgr.Model.UserRole>(); //需要插入角色的sql语句集合
            List <DriveMgr.Model.UserRole> role_deleteList = new List <DriveMgr.Model.UserRole>(); //需要删除角色的sql语句集合

            string[] str_userid = userIds.Trim(',').Split(',');
            string[] str_role   = roleIds.Trim(',').Split(',');

            DriveMgr.Model.UserRole userroledelete = null;
            DriveMgr.Model.UserRole userroleadd    = null;
            for (int i = 0; i < str_userid.Length; i++)
            {
                //批量设置先删除当前用户的所有角色
                userroledelete        = new DriveMgr.Model.UserRole();
                userroledelete.UserId = Convert.ToInt32(str_userid[i]);
                role_deleteList.Add(userroledelete);

                if (!string.IsNullOrEmpty(roleIds))
                {
                    //再添加设置的角色
                    for (int j = 0; j < str_role.Length; j++)
                    {
                        userroleadd        = new DriveMgr.Model.UserRole();
                        userroleadd.UserId = Convert.ToInt32(str_userid[i]);
                        userroleadd.RoleId = Convert.ToInt32(str_role[j]);
                        role_addList.Add(userroleadd);
                    }
                }
            }
            return(dal.SetRoleBatch(role_addList, role_deleteList));
        }
Esempio n. 2
0
        /// <summary>
        /// 设置用户角色(单个用户)
        /// </summary>
        /// <param name="userId">用户主键</param>
        /// <param name="roleIds">角色id,多个逗号隔开</param>
        public bool SetRoleSingle(int userId, string roleIds)
        {
            DataTable dt_user_role_old = new DriveMgr.BLL.Role().GetRoleByUserId(userId);          //用户之前拥有的角色
            List <DriveMgr.Model.UserRole> role_addList    = new List <DriveMgr.Model.UserRole>(); //需要插入角色的sql语句集合
            List <DriveMgr.Model.UserRole> role_deleteList = new List <DriveMgr.Model.UserRole>(); //需要删除角色的sql语句集合

            string[] str_role = roleIds.Trim(',').Split(',');                                      //传过来用户勾选的角色(有去勾的也有新勾选的)

            DriveMgr.Model.UserRole userroledelete = null;
            DriveMgr.Model.UserRole userroleadd    = null;
            //用户去掉勾选的角色(要删除本用户的角色)
            for (int i = 0; i < dt_user_role_old.Rows.Count; i++)
            {
                //等于-1说明用户去掉勾选了某个角色 需要删除
                if (Array.IndexOf(str_role, dt_user_role_old.Rows[i]["roleid"].ToString()) == -1)
                {
                    userroledelete        = new DriveMgr.Model.UserRole();
                    userroledelete.RoleId = Convert.ToInt32(dt_user_role_old.Rows[i]["roleid"].ToString());
                    userroledelete.UserId = userId;
                    role_deleteList.Add(userroledelete);
                }
            }

            //用户新勾选的角色(要添加本用户的角色)
            if (!string.IsNullOrEmpty(roleIds))
            {
                for (int j = 0; j < str_role.Length; j++)
                {
                    //等于0那么原来的角色没有 是用户新勾选的
                    if (dt_user_role_old.Select("roleid = '" + str_role[j] + "'").Length == 0)
                    {
                        userroleadd        = new DriveMgr.Model.UserRole();
                        userroleadd.UserId = userId;
                        userroleadd.RoleId = Convert.ToInt32(str_role[j]);
                        role_addList.Add(userroleadd);
                    }
                }
            }
            if (role_addList.Count == 0 && role_deleteList.Count == 0)
            {
                return(true);
            }
            else
            {
                return(dal.SetRoleSingle(role_addList, role_deleteList));
            }
        }