ASP.NET通用权限组件思路设计
开篇
做任何系统都离不开和绕不过权限的控制,尤其是B/S系统工作原理的特殊性使得权限控制起来更为繁琐,所以就在想是否可以利用IIS的工作原理,在IIS处理客户端请求的某个入口或出口通过判断URL来达到控制权限的目的,这样就可以减少通常要在每个页面或按钮都要添加的权限验证代码。
通常的权限验证模式
一般的权限验证会控制到菜单(页面)就可以满足,复杂一点的会要求控制到按钮(功能点),这个都需要做一下几点工作:
1.按权限生成菜单,这是所有系统都要做的;
2.在每个页面的开始处添加登录和权限的验证,调用公共的验证方法,这个地方经常将页面的编号搞混;
3.隐藏(或这直接不生成)页面上没有权限的按钮;
4.在功能的响应点添加权限验证代码,添加、修改、删除等功能的后台处理入口处加判断。
这四个步骤中2、3、4都是比较繁琐的,非常容易搞错页面或功能的编号(通常是复制过来忘记修改),B/S系统要做好权限验证杜绝漏洞这四个点的控制都很重要的,当然不需要控制到按钮的第三步就可以省略了,有些时候大家会忽略对第四步的验证,比如在调用.ashx(一般处理程序)页面处理操作请求时,并没有在.ashx后台的代码中进行权限(或登录)验证,这样就存在安全隐患了。
新的的权限验证模式设计
新的权限验证模式想要达到的目的是将上面的 2、3、4繁琐的权限验证调用去掉,在IIS处理请求的总入口或出口通过请求的URL判断是否有权限,根据判断的结果对请求进行不同的处理(终止、跳转、提示或正常处理)。
通过查阅互联网资料发现可以通过httpModules来实现,对httpModules的详细介绍请参照点击打开链接
httpModules介绍博客地址: http://www.cnblogs.com/chenlulouis/archive/2009/12/18/1626918.html
通用权限验证组件设计:
1.选择在httpModules的PreRequestHandlerExecute事件作为权限验证控制点,在这个事件前面的其它事件Session还没有生效无法取到用户信息,越往后的事件所处理完成的请求越多,权限认证肯定是越早越好,所以就选择了这个事件。
2.通过配置文件控制权限的验证,需要配置的点主要有:
2.1基础配置:数据库连接字符串、URL截取规则、登录页面(为登录时跳转)、提示信息(没有权限时)、登录验证Session标志;
2.2验证URL:URL拼接参数配置(有些页面要拼接参数后作为整体判断权限);
2.3需验证页面:限定验证范围,图片、js文件这些肯定是不需要验证的,需要验证的通常情况下也都是可预知的,可按后缀名或路径配置;
2.4忽略验证页面:在需要验证的配置范围内有些页面是不需要验证的,如登录页、主框架页、修改密码等,可按后缀名或路径配置;
2.5权限查询语句:根据取到的URL判断登录用户是否有权限的SQL语句和语句参数;
2.6字功能查询语句:查询有权限的子功能的SQL语句和语句参数,权限需要控制到按钮时才需要。
3.实现参数的导入、解析按配置的要求实现权限的验证控制。
结尾
这样一个简单的ASP.NET通用权限验证组件就设计完毕了,接下来就是用代码实现了,本人计划用C#代码实现这个设计,主要是想通过这个组件的开发加深对IIS工作原理的认识和理解,提升开发通用功能的能力。
ASP.NET通用权限组件思路设计的更多相关文章
- ASP.NET通用权限组件实现一
沙发(SF)通用权限验证组件 开篇 上一篇提到了通用权限的设计思路,根据设计思路一步一步的来实现一个相对通用的权限验证组件.在VS2010下用C#语言基于.net framework2.0框架实现具体 ...
- ASP.NET通用权限系统快速开发框架
系统在线演示地址: http://120.90.2.126:8051 登录账户:system,密码:system### DEMO下载地址: http://download.csdn.net/detai ...
- ASP.NET通用权限验证组件实现
沙发(SF)通用权限验证组件 开篇 本篇介绍通用权限验证的实现代码思路,总共分为导入参数.解析XML.根据XML配置进行处理.返回结果. 代码架构图 1. 类介绍 1.SFWebPermissio ...
- ASP.NET通用权限框架 权限管理系统源码jquery 精美UI源码
软件技术开发,合作请联系QQ:858-048-581 开发工具 VS2010 .sql2005.2008等(在Sql server数据执行脚本即可) VS2010 打开保证本地运行成功(数据库.源代 ...
- ASP.NET MVC权限控制思路
在系统开发的时候一个老生常谈的权限管理问题,翻阅了很多的网络资料,但是总感觉离实际使用还有一段距离,其实权限控制无非就几个“请求.页面按钮.字段显示”, 对于前端权限就需要配合JS了, 这里主要展示我 ...
- asp.net MVC通用分页组件 使用方便 通用性强
asp.net MVC通用分页组件 使用方便 通用性强 该分页控件的显示逻辑: 1 当前页面反色突出显示,链接不可点击 2 第一页时首页链接不可点击 3 最后一页时尾页链接不可点击 4 当前页面左 ...
- asp.net MVC通用权限管理系统-响应式布局-源码
一.Angel工作室简单通用权限系统简介 AngelRM(Asp.net MVC Web api)是基于asp.net(C#)MVC+前端bootstrap+ztree+lodash+jquery技术 ...
- 基于asp.net(C#)MVC+前端bootstrap+ztree+lodash+jquery技术-Angel工作室通用权限管理
一.Angel工作室简单通用权限系统简介 AngelRM(Asp.net MVC Web api)是基于asp.net(C#)MVC+前端bootstrap+ztree+lodash+jquery技术 ...
- ASP.NET MVC通用权限管理系统(响应布局)源码更新介绍
一.asp.net mvc 通用权限管理系统(响应布局)源码主要以下特点: AngelRM(Asp.net MVC)是基于asp.net(C#)MVC+前端bootstrap+ztree+lodash ...
随机推荐
- 【SQL学习笔记】排名开窗函数,聚合开窗函数(Over by)
处理一些分组后,该组按照某列排序后 ,取其中某条完整数据的问题. 或 按照其中不同列分组后的聚合 比如 sum,avg之类. MSDN上语法: Ranking Window Functions < ...
- cookie丢失、登陆自动退出问题解决
cookie保存在客户端或者内存中,不易丢失.但是在某些情况下会被忽略.在项目过程中遇到过跨域丢失的情况.在VS里面运行的程序,产生的cookie默认是没有domain值的,但是给它设定domain值 ...
- C# using垃圾回收详解
简介 定义一个范围,将在此范围之外释放一个或多个对象. 语法 using (Font font1 = new Font("Arial", 10.0f)) { } C# 语言参考 主 ...
- Spring mvc中@RequestMapping 6个基本用法整理
继续整理,这个是前段时间用jsp开发的一个站点,说起来php程序员去做jsp程序确实有些小不适应,但是弄完后绝对对于这种强类型语言而比收获还是颇多的. 1,最基本的,方法级别上应用 @RequestM ...
- (原+转)使用opencv的DFT计算卷积
转载请注明出处: http://www.cnblogs.com/darkknightzh/p/5462665.html 参考网址: http://blog.csdn.net/lichengyu/art ...
- android ant 最简单的打包签名,混淆方法
使用ant打包,如果脚本都是我们自己一步一步来写的话,是一个比较麻烦的东西. 关于ant,我们详细看下: ant支持 ant debug,ant release等命令,我们需要签名混淆,那么就需要an ...
- Maven 学习笔记
1. Maven 工具的意义: 从事软件开发,无论什么样的项目,什么样的技术,都要经历:编码.测试.打包.发布等几个特定过程,而这些过程在软件开发周期中都是重复的.繁琐的.Maven的出现是为了将开发 ...
- 关于《Cocos2d-x建工程时避免copy文件夹和库》的更新
在前几篇博文中大概了解了Cocos2d-x引擎的基本结构后打算开始实际操作,便在网上转载了一篇关于VS新建Cocos2d-x项目的文章.今天实际操作的时候发现博主使用的引擎版本和我的不一致(<C ...
- Rectangle and Square
Description Little Petya very much likes rectangles and especially squares. Recently he has received ...
- 使用Spring Boot和Gradle创建AngularJS项目
Spring Boot 是由 Pivotal 团队提供的全新框架,其设计目的是用来简化新 Spring 应用的初始搭建以及开发过程.该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的 ...