ASP.NET MVC+EF框架+EasyUI实现权限管理系列(23)-设置角色遗留问题和为权限设置角色以及EasyUI Tabs的使用
ASP.NET MVC+EF框架+EasyUI实现权限管系列
(开篇) (1):框架搭建 (2):数据库访问层的设计Demo (3):面向接口编程 (4 ):业务逻辑层的封装
(5):前台Jquery easyUI实现 (6):EF上下文实例管理 (7):DBSession的封装 (8):DBSession线程内唯一
(9):TT摸版的学习 (10):VSS源代码管理 (11):验证码实现和底层修改 (12):实现用户异步登录和T4模板
(13):权限设计 (14):主框架搭建 (15):权限数据库模型和用户登录详细错误 (16):用户注册的各种验证
(17):注册用户功能的细节处理 (18):过滤器的使用和批量删除数据(伪删除和直接删除)
(19):用户信息的修改和浏览 (20):多条件模糊查询和回收站还原的实现 (21):用户角色权限基本的实现说明
前言:这段时间博客的更新比较慢,主要是这段时间工作上面比较忙点,晚上回来在吹吹风,写一点点的代码就能休息了,所以用了这段时间把代码基本写完了,但是博客的更新速度比较慢,主要是后面的这部分内容感觉博客不好写,一会在页面,一会在控制器,一会又在Model中操作,感觉写的乱而不识,虽然是这样,但是我们还是要写下去,给大家一个成型的东西才能感觉大完善,希望大家能够理解,那么今天我们就开始说我们今天的内容,今天的内容主要有这几个方向,(1):完善上篇博客中遗留的问题,(2):为用户设置权限,这个的实现效果和上篇博客基本一样,所以这里也就是基本提一下就行,(3):重新对页面进行布局,实现Tab页面。
1. 为用户设置角色遗留问题—全局查询
(1)上篇博客我们基本说完了为用户设置角色,但是我们按照以前的代码书写的话发现了一个问题,那就是我们的用户数据查询不到了,这是什么原因呢?其实原因也很简单,那就是用户和角色是多对多的关系,当我们为用户设置角色的话,用户表中会存放角色表的实体,而角色表则会存放用户表的实体,这个我们可以在Edmx模型中看到,那么为什么会这样呢?原因就是当我们序列化BaseUser实体的时候,发现含有BaseRole属性,这时候就要序列化BaseRole属性,这时候EF提供了一个序列化导航属性的时候的延迟加载起作用了,这样的话他就会循环的去查询BaseRole和BaseUser实体类,这样序列化的话就会发生死循环,所以会报错。
(2)根据上面我们也知道了以前的代码会出现错误,那么我们怎么避免这个错误,使我们的用户显示出来数据呢?其实我们只需要用linq将BaseUser字段全部查询出来即可,最后对用户的控制器查询效果修改之后的代码如下所示:
/// <summary>
/// 获取所有的用户信息
/// </summary>
/// <returns>返回用户详细信息的Json对象</returns>
public ActionResult GetAllUserInfos()
{
//Json格式的要求{total:22,rows:{}}
//实现对用户分页的查询,rows:一共多少条,page:请求的当前第几页
int pageIndex = Request["page"] == null ? : int.Parse(Request["page"]);
int pageSize = Request["rows"] == null ? : int.Parse(Request["rows"]);
//得到多条件查询的参数
string RealName = Request["RealName"];
string Telephone = Request["Telephone"];
string EMail = Request["EMail"];
int? Enabled = Request["Enabled"] == null ? - : int.Parse(Request["Enabled"]);
string AuditStatus = Request["AuditStatus"];
int? DeletionStateCode = Request["DeletionStateCode"] == null ? : int.Parse(Request["DeletionStateCode"]);
int total = ;
//调用分页的方法,传递参数,拿到分页之后的数据
//var data = _userInfoService.LoadPageEntities(pageIndex, pageSize, out total,
// u => true && u.DeletionStateCode == 0, true, u => u.SortCode);
//封装一个业务逻辑层的方法,来处理分页过滤事件
var userInfoQuery = new UserInfoQuery()
{
PageSize = pageSize,
PageIndex = pageIndex,
RealName = RealName,
Telephone = Telephone,
EMail = EMail,
Enabled = Enabled,
AuditStatus = AuditStatus,
Total = ,
DeletionStateCod = DeletionStateCode
};
//如果含有导航属性关联的话,出现循环引用的问题,死循环
var data = from u in _userInfoService.LoadSearchData(userInfoQuery)
select new
{
u.ID,u.AuditStatus,u.Birthday,u.ChangePasswordDate,u.Code,u.CreateBy,u.CreateOn,u.CreateUserID,u.DeletionStateCode,u.DepartmentID,u.Description,u.Email,u.Enabled,u.Gender,u.HomeAddress,u.IsStaff,u.IsVisible,u.Mobile,u.ModifiedBy,u.ModifiedUserID,u.ModifirdOn,u.QICQ,u.QuickQuery,u.RealName,u.SecurityLevel,u.SortCode,u.Telephone,u.Title,u.UserFrom,u.UserName,u.UserPassword
};
//构造成Json的格式传递
var result = new { total = userInfoQuery.Total, rows = data };
//return JsonDate(result);
return Json(result, JsonRequestBehavior.AllowGet);
}
(3)通过上述的代码实现我们就解决了我们前面提到我们遇到的问题,这里大家如果有什么不懂的话可以给我留言,可能我的预言表达能力不怎么好,只能表达到这里了。
2.为权限设置角色
(1)上述我们看到的这个标题大致的实现思路是固定的,因为我们在上一篇博客中已经介绍过了,为用户设置角色,这几个大的模块的实现思路基本是一样的,所以在这篇博客中我就不再介绍了,代码我都已经写完,希望大家可以参考上篇博客来实现这个功能。
(2)那么我们为什么给权限设置角色呢?看我们的Edmx模型其实大致就知道了,我这里简单的说一下,为用户设置角色,我们的角色中必然要对应于权限的操作,所有这样就出现了我们要为权限设置角色。
(3)实现效果如图所示:

3.EasyUI Tabs标签页面的实现
(1)在说这个的使用之前我们首先看一下我们以前的前台页面的架构,如图所示:
(2)那么看我们现在项目的前台页面的架构,我们可以发现我们引入了EasyUI Tabs之后的变化,如图所示:
(3)EasyUI Tabs控件实现了,但是在这里我们就会遇到当我们重复单击右边的导航的时候会发生什么变化,那么主要的代码如下:
//绑定菜单按钮的点击事件 MenuLink
function BindMenuClickEvent() {
$(".MenuLink").click(function () {
//获取按钮里面的src属性
var src = $(this).attr("src");
//将主框架的iframe跳转到菜单指向的地址
//$("#frmWorkArea").attr("src", src);
//得到节点的名字来放去Title
var title = $(this).text();
//拼接一个Iframe标签
var str = '<iframe id="frmWorkArea" width="100%" height="100%" frameborder="0" scrolling="yes" src="' + $(this).attr("src") + '"></iframe>'
//首先判断用户是否已经单击了此项,如果单击了直接获取焦点,负责打开
var isExist = $("#worktab").tabs('exists', title);
if (!isExist) {
//添加tab的节点,调用easyUITab标签的方法
$("#worktab").tabs('add', {
title: title,
content: str,
iconCls: 'icon-save',
closable: true
});
}
else {
//如果存在则获取焦点
$("#worktab").tabs('select', title);
}
});
}
4.这篇博客到这里基本就已经写完了,大家阅读的时候如果有什么问题可以给我留言,我将会在第一时间回复,这篇博客大家看起来可能有点吃力,因为不连贯,所以大家能够看看前面的博客在看这篇博客的时候将会很顺心的,那么下篇博客我们开始讲述权限组的实现。
源码下载
(1):完整源码下载
Kencery返回本系列开篇
ASP.NET MVC+EF框架+EasyUI实现权限管理系列(23)-设置角色遗留问题和为权限设置角色以及EasyUI Tabs的使用的更多相关文章
- ASP.NET MVC+EF框架+EasyUI实现权限管理系列(24)-权限组的设计和实现(附源码)(终结)
ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇) (1):框架搭建 (2):数据库访问层的设计Demo (3):面向接口编程 (4 ):业务逻辑层的封装 ...
- ASP.NET MVC+EF框架+EasyUI实现权限管理系列(22)-为用户设置角色
ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇) (1):框架搭建 (2):数据库访问层的设计Demo (3):面向接口编程 (4 ):业务逻辑层的封装 ...
- ASP.NET MVC+EF框架+EasyUI实现权限管理系列
http://www.cnblogs.com/hanyinglong/archive/2013/03/22/2976478.html ASP.NET MVC+EF框架+EasyUI实现权限管理系列之开 ...
- ASP.NET MVC+EF框架+EasyUI实现权限管理系列(21)-用户角色权限基本的实现说明
原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(21)-用户角色权限基本的实现说明 ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇) (1):框 ...
- ASP.NET MVC+EF框架+EasyUI实现权限管理系列(20)-多条件模糊查询和回收站还原的实现
原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(20)-多条件模糊查询和回收站还原的实现 ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇) (1):框架 ...
- ASP.NET MVC+EF框架+EasyUI实现权限管理系列(19)-用户信息的修改和浏览
原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(19)-用户信息的修改和浏览 ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇) (1):框架搭建 ...
- ASP.NET MVC+EF框架+EasyUI实现权限管理系列(18)-过滤器的使用和批量删除数据(伪删除和直接删除)
原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(18)-过滤器的使用和批量删除数据(伪删除和直接删除) ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇) ...
- ASP.NET MVC+EF框架+EasyUI实现权限管理系列(17)-注册用户功能的细节处理(各种验证)
原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(17)-注册用户功能的细节处理(各种验证) ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇) (1):框 ...
- ASP.NET MVC+EF框架+EasyUI实现权限管理系列(16)-类库架构扩展以及DLL文件生成修改和用户的简单添加
原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(16)-类库架构扩展以及DLL文件生成修改和用户的简单添加 ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇) ...
随机推荐
- 浏览器执行js代码的机制--对于我们深入了解js有很大的帮助,同时面试时候也都能用得到。
前端小菜又来了,这些天每天工作,晚上学习太累了.趁星期天给自己放个假.写完这个博客就要出去high了.鸡冻.接下来进入正题啦, 你可能要问,我们学习这个有什么用啊?这样我先给大家来个小小的面试题. a ...
- iOS-在团队开发过程中控制代码版本
Cornerstone Svn简单使用指南: -- what if 负责编写 一.安装并拷贝项目 1.第一步:安装svn.2.第二步:第一个使用svn,找到“Check Out Working Cop ...
- 浅谈HTML5单页面架构(一)——requirejs + angular + angular-route
心血来潮,打算结合实际开发的经验,浅谈一下HTML5单页面App或网页的架构. 众所周知,现在移动Webapp越来越多,例如天猫.京东.国美这些都是很好的例子.而在Webapp中,又要数单页面架构体验 ...
- 对Big Table进行全表更新,导致 Replication 同步数据的过程十分缓慢
在Publisher database中更新一个big table,数据行数是3.4亿多.由于没有更新 clustered Index key,因此,只产生了3.4亿多个Update Commands ...
- Hello World of OpenCascade
Hello World of OpenCascade eryar@163.com 摘要Abstract:以一个经典的Hello World程序为例开始对开源几何造型内核OpenCascade的学习. ...
- TortoiseGit与github实现项目的上传
1. 下载并安装相关软件 这里主要涉及的软件包括msysgit和TortoiseGit. msysgit的下载地址:http://msysgit.googlecode.com/files/Git-1. ...
- .Net 转战 Android 4.4 日常笔记目录
.Net 转战 Android 4.4 日常笔记(1)--工具及环境搭建 .Net 转战 Android 4.4 日常笔记(2)--HelloWorld入门程序 .Net 转战 Android 4.4 ...
- 【开源】OSharp框架解说系列(2.1):EasyUI的后台界面搭建及极致重构
OSharp是什么? OSharp是个快速开发框架,但不是一个大而全的包罗万象的框架,严格的说,OSharp中什么都没有实现.与其他大而全的框架最大的不同点,就是OSharp只做抽象封装,不做实现.依 ...
- AngularJS之中级Route【二】(七)
前言 上一篇我们介绍了AngularJS内置的路由ngRoute,我们知道AngularJS被广泛应用于单页应用SPA(Single Page Application)中,此时路由对于我们来讲非常重要 ...
- Git 冲突合并
在多人协作开发,经常遇到Git冲突,每次都不大记住命令.所以自己备注一下! git pull 之后有冲突: $ git pullremote: Counting objects: 5, done.re ...