- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
HYPERLINK /Leejor/archive/2010/03/04/1678597.html A MVC权限设计思考 (一)数据库建库部分
?目前各类的权限设计已经困扰了我们好久,对于MVC,下面我将通过ActionFilter来扩展我们的权限认证,以下示例是从我的一个课程中心项目中提取出来,希望对各位初学者起到抛砖引玉的作用。
下面首先来设计我们的权限控制的数据库层。
下面我来依次介绍每个字段的说明
RoleGroup 权限组表? 该表主要对系统权限进行分组,我们的用户可以直接赋予该分组,拥有所有该组权限
RoleID 权限组ID 例:01
RoleName 权限组名称? 例:系统管理员
RoleState 组状态 (是否启用) 例:True
?
RoleGroupAppList 表 组权限对应表 该表主要复制每个权限组对应的权限详细列表
ID ID主键 例:1
RoleID 对应权限组的ID 例:01
SysAppID 对应的详细权限组ID 例:01
StartTime 该权限使用的起始日期 例:2009-01-01 ,该字段属性默认为:all ,即不限制起始日期
EndTime 该权限使用的结束日期 例:2009-01-01 ,该字段属性默认为:all ,即不限制结束日期
?
SysAppCate 表 该表主要是对SysAppList详细权限表做分类,当我们的权限页面特别多的时候,该表主要为了方便管理。可省略
SysAppCateID 大类ID 例:01
SysAppCateName 大类名称 例:新闻管理
SysAppCateEName 大类英文名
?
SysAppList 权限详细表 该表主要负责所有权限的基础列表
SysAppID 权限ID 例:01
SysAppCateID 权限大类ID 例:01
SysAppName 权限名称 例:新闻添加
SysAppEName 权限英文名称
SysAppController 权限对应的Controller 例:News
SysAppAction 权限对应的Action 例:Add 本权限设计针对对Action权限限制
IsView 是否为可见 例:True 该字段的设计主要是便于后台的管理和设置,因为有部分Action是没有View层的,比如Post,但是在后台权限管理中我们又要用到他。
?
好了,建库部分就到这里了,下一篇我会介绍逻辑部分,其中会涉及到Repository模式,缓存,自定义的AuthorizeAttribute。
HYPERLINK /Leejor/archive/2010/03/05/1679107.html A MVC权限设计思考 (二)逻辑部分实现
在我的项目中,我还是使用的LINQ TO SQL ,因为我的项目不会涉及太多很太复杂的数据库操作业务。当然如果设计,我相信LINQ TO SQL的自定义扩展也能满足需求。
使用Repository模式是最近MVC很多项目采用的解决方案,能把原来我们杂乱的LINQ TO SQL统一封装起来。让我们的架构更清晰。
现在来看看具体实现。
IRepository接口:
代码
interface?IRepositoryTEntity?where?TEntity?:?class????{????????IQueryableTEntity?FindAll(ExpressionFuncTEntity,?bool?exp);????????TEntity?Find(ExpressionFuncTEntity,?bool?exp);????????void?Add(TEntity?entity);????????void?Delete(TEntity?entity);????????void?Save();????}
?
Repository实现:
代码
?public?class?RepositoryTEntity?:?IRepositoryTEntity?where?TEntity?:?class????{????????protected?DAL.CourseCenterData?db;????????public?Repository()????????{????????????db?=?new?DAL.CourseCenterData();????????????????????}????????///?summary????????///?查找所有数据????????///?/summary????????///?returns/returns????????public?IQueryableTEntity?FindAll()????????{????
文档评论(0)