asp.net权限控制的方式

我们在使用asp.net开发Web程序的时候经常需要进行一些权限控制,如:

限制用户没有登陆就无法查看一些页面,又或者是说登陆之后如果不是管理员,或是没有响应的权限就无法进行相关的操作。

实现的方法有很多,最简单也是最笨的方式就是在每个需要权限控制的页面都写一段代码来进行逻辑判断,

在高级一点就是将这些个代码抽象出来形成一个方法,需要使用时调用即可。


之前的之前,我也是用上面的方法来做权限控制的(= =我很菜),不过自从某一天学习到了一个吊炸天的方式之后,哈哈,从此变身高(土)富(掉)帅(渣)。

废话不说,马上开始:

首先,需要定义一个类,叫什么都行,我的就叫BasePage吧

public class BasePage : System.Web.UI.Page
    {
        protected override void OnInit(EventArgs e)
        {
            base.OnInit(e);
            if (Session["User"] == null)
            {
                HttpContext context = HttpContext.Current;
                context.Response.Redirect("Login.aspx?url=" + context.Request.Url.ToString());
            }
        }
    }

BasePage类必须继承 System.Web.UI.Page

然后再其中重写Page类的OnInit方法,在其中先执行Page基类自己的OnInit(),之后加入自己的权限控制代码
那么,为什么要这么做呢?
由上面的代码我们可以看到,由于BasePage继承了Page类,而据我们所知,Page类是所有的aspx的基类,也就是说,当你请求一个aspx页面的时候,该页面会经过一个完整的生命周期(简单的可以理解成,从开始创建到结束销毁,真正的生命周期过程十分复杂),在生命周期中,都会先执行Page类的OnInit方法。
说白了就是,不管你怎么搞,Page类的这个OnInit方法一定会被执行。
那么,在我们的BasePage类中,继承了Page类并重写OnInit方法有什么用呢?
这时候你想想,如果让一个aspx页面不在直接继承于Page类,而是我们自己定义的BasePage类,会出现什么情况??
------------------无耻的分割线--------------------
答案很明显:aspx页面继承于BasePage,也相当于继承了Page类,是Page类的孙子类(不明白的打道回府看书去~)
而这个时候Page类的OnInit方法被BasePage类重写了!
所以当aspx生命周期到要执行Pge类的OnInit方法的时候,会执行这个重写的方法。
而在这个重写的方法中,又调用了Page类的OnInit方法,保证了原来的页面生命周期不会出现异常,
而在执行完Page类的OnInit方法之后,重点来了
生命周期会继续执行我们自己写的权限控制的代码,执行完毕之后才回去进行生命周期中的另外过程。
这就实现了,只要aspx页面继承了BasePage,任何请求都会经过一系列的自定义的权限判断。
是不是很吊!!!(当然或许是我土,不知道= =)
当然,权限控制的代码有可能很复杂,上面只是一个简单的例子,仅供参考。
例子的功能是,检查Session中User是否为空,空表示没有登录,跳转到登陆页面,并将原来用户浏览的页面url当做参数传给登陆页面,以便用户登录之后可以继续浏览刚刚的页面(这个功能我觉得不错哟~)
最后,关于页面的生命周期,很复杂,有时间会整理一些自己的理解上来,to be continue...

1、菜单导航管理 2、操作按钮 3、角色管理 4、部门管理 5、用户管理(用户权限) 6、用户组管理(设置成员,用户组权限) 7、系统配置(动态配置系统参数) 8、附加属性(自定义属性) 9、系统日志(异常记录) 10、数据库备份/还原 11、资源管理,(动态数据库) 12、个人信息(基本信息,附加信息,用户角色,拥有权限) 13、首页快捷 14、数据回收站(业务功能删除过数据,全部保留在回收站) 15、系统个性化设置(切换菜单导航) 系统UI,给人感觉非常好,体积小巧,速度快 该源码是适用用于应用系统后台模块的管理(可扩展至支持集中化的权限管理平台), 0.支持N级菜单导航,菜单显示方式支持目前支持2种模式分别:菜单(无限级),横向(2级) 1.动态切换皮肤,目前有两狂UI 蓝色,咖啡色 2.表单验证,文本框高亮起来 3.可以动态分配权限按钮,分配角色权限,目录结构,栏目的链接都可以修改。权限管理非常灵活, 4.可以隐藏左侧导航栏,打开左侧导航栏,默认是打开,table表格都自应大小的 5.动态创建数据表,删除用户表,点击数据 表 可以查询字段信息 6.可以直接执行sql脚本 7.兼容 IE6,7,8,9 /Firefox /Google Chrome 这些浏览器都测试过 8.批量删除,自定义复选框样式,可以全选/反选 9.角色分级,集团和分公司的关系 10.权限 横向就是业务部分,具体负责哪块业务,纵向是级别 11.动态报表设置,并且可以导出Excel 12.登陆日记,操作日记,异常日记 13.海量批量删除数据库,调用公共存储过程,参数,表明,主键 特点: UI:传统html css,美观 漂亮 大方 实用 js框架:jquery 系统大部分使用AJAX操作。大大提高了用户体验 功能描述: 1.支持N级菜单导航,菜单显示方式支持目前支持2种模式分别: 菜单(无限级),横向(2级) 2.表单验证,文本框高亮起来 3.可以动态分配权限按钮,分配角色权限,目录结构,栏目的链接都可以修改。 4.可以隐藏左侧导航栏,打开左侧导航栏,默认是打开,table表格都自应大小的 5.动态创建数据表,删除用户表,点击数据 表 可以查询字段信息 6.可以直接执行sql脚本
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值