ASP.NET MVC+EF框架+EasyUI实现权限管理系列(23)-设置角色遗留问题和为权限设置角色以及EasyUI Tabs的使用

简介: 原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(23)-设置角色遗留问题和为权限设置角色以及EasyUI Tabs的使用  ASP.NET MVC+EF框架+EasyUI实现权限管系列   (开篇)   (1):框架搭建    (2):数据库访问层的设计Demo    (3...
原文: 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):用户角色权限基本的实现说明

    (22):为用户设置角色

  前言:这段时间博客的更新比较慢,主要是这段时间工作上面比较忙点,晚上回来在吹吹风,写一点点的代码就能休息了,所以用了这段时间把代码基本写完了,但是博客的更新速度比较慢,主要是后面的这部分内容感觉博客不好写,一会在页面,一会在控制器,一会又在Model中操作,感觉写的乱而不识,虽然是这样,但是我们还是要写下去,给大家一个成型的东西才能感觉大完善,希望大家能够理解,那么今天我们就开始说我们今天的内容,今天的内容主要有这几个方向,(1):完善上篇博客中遗留的问题,(2):为用户设置权限,这个的实现效果和上篇博客基本一样,所以这里也就是基本提一下就行,(3):重新对页面进行布局,实现Tab页面。

1. 为用户设置角色遗留问题—全局查询

  (1)上篇博客我们基本说完了为用户设置角色,但是我们按照以前的代码书写的话发现了一个问题,那就是我们的用户数据查询不到了,这是什么原因呢?其实原因也很简单,那就是用户和角色是多对多的关系,当我们为用户设置角色的话,用户表中会存放角色表的实体,而角色表则会存放用户表的实体,这个我们可以在Edmx模型中看到,那么为什么会这样呢?原因就是当我们序列化BaseUser实体的时候,发现含有BaseRole属性,这时候就要序列化BaseRole属性,这时候EF提供了一个序列化导航属性的时候的延迟加载起作用了,这样的话他就会循环的去查询BaseRole和BaseUser实体类,这样序列化的话就会发生死循环,所以会报错。

  (2)根据上面我们也知道了以前的代码会出现错误,那么我们怎么避免这个错误,使我们的用户显示出来数据呢?其实我们只需要用linq将BaseUser字段全部查询出来即可,最后对用户的控制器查询效果修改之后的代码如下所示:

 1         /// <summary>
 2 
 3         /// 获取所有的用户信息
 4 
 5         /// </summary>
 6 
 7         /// <returns>返回用户详细信息的Json对象</returns>
 8 
 9         public ActionResult GetAllUserInfos()
10 
11         {
12 
13             //Json格式的要求{total:22,rows:{}}
14 
15  
16 
17             //实现对用户分页的查询,rows:一共多少条,page:请求的当前第几页
18 
19             int pageIndex = Request["page"] == null ? 1 : int.Parse(Request["page"]);
20 
21             int pageSize = Request["rows"] == null ? 10 : int.Parse(Request["rows"]);
22 
23             //得到多条件查询的参数
24 
25             string RealName = Request["RealName"];
26 
27             string Telephone = Request["Telephone"];
28 
29             string EMail = Request["EMail"];
30 
31             int? Enabled = Request["Enabled"] == null ? -1 : int.Parse(Request["Enabled"]);
32 
33             string AuditStatus = Request["AuditStatus"];
34 
35             int? DeletionStateCode = Request["DeletionStateCode"] == null ? 0 : int.Parse(Request["DeletionStateCode"]);
36 
37             int total = 0;
38 
39             //调用分页的方法,传递参数,拿到分页之后的数据
40 
41             //var data = _userInfoService.LoadPageEntities(pageIndex, pageSize, out total,
42 
43             //    u => true && u.DeletionStateCode == 0, true, u => u.SortCode);
44 
45             //封装一个业务逻辑层的方法,来处理分页过滤事件
46 
47             var userInfoQuery = new UserInfoQuery()
48 
49             {
50 
51                 PageSize = pageSize,
52 
53                 PageIndex = pageIndex,
54 
55                 RealName = RealName,
56 
57                 Telephone = Telephone,
58 
59                 EMail = EMail,
60 
61                 Enabled = Enabled,
62 
63                 AuditStatus = AuditStatus,
64 
65                 Total = 0,
66 
67                 DeletionStateCod = DeletionStateCode
68 
69             };
70 
71              //如果含有导航属性关联的话,出现循环引用的问题,死循环
72 
73             var data = from u in _userInfoService.LoadSearchData(userInfoQuery)
74 
75                        select new
76 
77                        {
78 
79                            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
80 
81             };
82 
83             //构造成Json的格式传递
84 
85             var result = new { total = userInfoQuery.Total, rows = data };
86 
87             //return JsonDate(result);
88 
89             return Json(result, JsonRequestBehavior.AllowGet);
90 
91         }

  (3)通过上述的代码实现我们就解决了我们前面提到我们遇到的问题,这里大家如果有什么不懂的话可以给我留言,可能我的预言表达能力不怎么好,只能表达到这里了。

2.为权限设置角色

  (1)上述我们看到的这个标题大致的实现思路是固定的,因为我们在上一篇博客中已经介绍过了,为用户设置角色,这几个大的模块的实现思路基本是一样的,所以在这篇博客中我就不再介绍了,代码我都已经写完,希望大家可以参考上篇博客来实现这个功能。

  (2)那么我们为什么给权限设置角色呢?看我们的Edmx模型其实大致就知道了,我这里简单的说一下,为用户设置角色,我们的角色中必然要对应于权限的操作,所有这样就出现了我们要为权限设置角色。

  (3)实现效果如图所示:

     

3.EasyUI Tabs标签页面的实现

  (1)在说这个的使用之前我们首先看一下我们以前的前台页面的架构,如图所示:

  (2)那么看我们现在项目的前台页面的架构,我们可以发现我们引入了EasyUI Tabs之后的变化,如图所示:

  (3)EasyUI Tabs控件实现了,但是在这里我们就会遇到当我们重复单击右边的导航的时候会发生什么变化,那么主要的代码如下:

 1 //绑定菜单按钮的点击事件  MenuLink
 2 
 3 function BindMenuClickEvent() {
 4 
 5    $(".MenuLink").click(function () {
 6 
 7        //获取按钮里面的src属性
 8 
 9        var src = $(this).attr("src");
10 
11        //将主框架的iframe跳转到菜单指向的地址
12 
13        //$("#frmWorkArea").attr("src", src);
14 
15        //得到节点的名字来放去Title
16 
17        var title = $(this).text();
18 
19        //拼接一个Iframe标签
20 
21        var str = '<iframe id="frmWorkArea" width="100%" height="100%" frameborder="0" scrolling="yes" src="' + $(this).attr("src") + '"></iframe>'
22 
23        //首先判断用户是否已经单击了此项,如果单击了直接获取焦点,负责打开
24 
25        var isExist = $("#worktab").tabs('exists', title);
26 
27        if (!isExist) {
28 
29             //添加tab的节点,调用easyUITab标签的方法
30 
31             $("#worktab").tabs('add', {
32 
33                 title: title,
34 
35                 content: str,
36 
37                 iconCls: 'icon-save',
38 
39                 closable: true
40 
41               });
42 
43            }
44 
45            else {
46 
47                //如果存在则获取焦点
48 
49                $("#worktab").tabs('select', title);
50 
51            }
52 
53        });
54 
55   }

4.这篇博客到这里基本就已经写完了,大家阅读的时候如果有什么问题可以给我留言,我将会在第一时间回复,这篇博客大家看起来可能有点吃力,因为不连贯,所以大家能够看看前面的博客在看这篇博客的时候将会很顺心的,那么下篇博客我们开始讲述权限组的实现。

   .NET开发者博客:www.kencery.com

    Kencery返回本系列开篇

目录
相关文章
|
2月前
|
前端开发 Java 程序员
从零基础手写Spring MVC框架,准备好进阶程序员了吗?
我们程序员大部分人都是野路子,不懂什么叫代码规范。写了一个月的代码,最后还得其他老司机花3天时间重构,相信大部分老司机都很头疼看新手的代码。
25 1
|
20天前
|
前端开发 安全 Java
使用Java Web框架:Spring MVC的全面指南
【4月更文挑战第3天】Spring MVC是Spring框架的一部分,用于构建高效、模块化的Web应用。它基于MVC模式,支持多种视图技术。核心概念包括DispatcherServlet(前端控制器)、HandlerMapping(请求映射)、Controller(处理请求)、ViewResolver(视图解析)和ModelAndView(模型和视图容器)。开发流程涉及配置DispatcherServlet、定义Controller、创建View、处理数据、绑定模型和异常处理。
使用Java Web框架:Spring MVC的全面指南
|
27天前
|
前端开发 JavaScript Java
MVC框架:SpringMVC(三)
MVC框架:SpringMVC
30 0
|
27天前
|
JSON 前端开发 JavaScript
MVC框架:SpringMVC(二)
MVC框架:SpringMVC
37 0
|
27天前
|
前端开发 Java 应用服务中间件
MVC框架:SpringMVC(一)
MVC框架:SpringMVC
60 0
|
1月前
|
开发框架 前端开发 .NET
进入ASP .net mvc的世界
进入ASP .net mvc的世界
29 0
|
1月前
mvc.net分页查询案例——mvc-paper.css
mvc.net分页查询案例——mvc-paper.css
5 0
|
1月前
|
开发框架 前端开发 .NET
C# .NET面试系列六:ASP.NET MVC
<h2>ASP.NET MVC #### 1. MVC 中的 TempData\ViewBag\ViewData 区别? 在ASP.NET MVC中,TempData、ViewBag 和 ViewData 都是用于在控制器和视图之间传递数据的机制,但它们有一些区别。 <b>TempData:</b> 1、生命周期 ```c# TempData 的生命周期是短暂的,数据只在当前请求和下一次请求之间有效。一旦数据被读取,它就会被标记为已读,下一次请求时就会被清除。 ``` 2、用途 ```c# 主要用于在两个动作之间传递数据,例如在一个动作中设置 TempData,然后在重定向到另
95 5
|
2月前
|
前端开发 Java 数据库连接
认识Java中最常用的框架:Spring、Spring MVC、Spring Boot、MyBatis和Netty
Spring框架 Spring是一个轻量级的开源框架,用于构建企业级应用。它提供了广泛的功能,包括依赖注入、面向切面编程、事务管理、消息传递等。Spring的核心思想是控制反转(IoC)和面向切面编程(AOP)。
77 3
|
3月前
|
XML 前端开发 定位技术
C#(NET Core3.1 MVC)生成站点地图(sitemap.xml)
C#(NET Core3.1 MVC)生成站点地图(sitemap.xml)
25 0