Asp.net 基于Cookie简易的权限判断

所属分类: 网络编程 / ASP.NET 阅读数: 580
收藏 0 赞 0 分享
写入Cookie页面,创建cookie后,设置cookie属性,并添加到Response.Cookies中读取cookie,利用cookie的名字或索引从Request.Cookies中取得改写Cookie,先创建一个同名的cookie,读取Request中同名的cookie,把读取cookie的属性值付给新的对象,加入到Response.Cookies中创建一个BasePage页面,其他的页面继承自这个页面,把权限判断的代码有单个页面的Page_Load转移到BasePage的PreLoad中,下面是BasePage的主要代码
复制代码 代码如下:

public class BasePage : System.Web.UI.Page
{
private string pageName;
public BasePage()
{
this.Page.PreLoad += Page_Load;
}
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
Uri r = this.Request.Url;
pageName = r.AbsolutePath;
if (NeedToCheck())
{
if (!HasAuthentication())
{
HttpContext.Current.Response.Redirect("NoAuthenticationPage.aspx");
}
}
}
}
private bool NeedToCheck()
{
if (pageName.Contains("NoAuthenticationPage.aspx") || pageName == "Login.aspx" )
{
return false;
}
return true;
}
private bool HasAuthentication()
{
//look into the config file or database,to see whether this page is in the allow accessing list of the role or not;
//the signature of the function is like this
//QueryInConfig(m_UserRole,pageName);
if (pageName.Contains("Default3.aspx") && UserRole == "2")
{
return false;
}
return true;
}
protected HttpCookie _RequestCookie;
protected HttpCookie _ResponseCookie;
private bool b_IsNewCookie = true;
public string UserRole
{
get
{
return GetCookieValue("UserRole");
}
set
{
SetCookieValue("UserRole", value);
}
}
public string UserName
{
get
{
return GetCookieValue("UserName");
}
set
{
SetCookieValue("UserName", value);
}
}
protected void SetCookieValue(string name, string value)
{
SetResponseCookie();
_ResponseCookie[name] = value;
}
private string GetCookieValue(string name)
{
SetReqeustCookie();
if (_RequestCookie != null)
{
return _RequestCookie[name];
}
return null;
}
protected void SetReqeustCookie()
{
_RequestCookie = HttpContext.Current.Request.Cookies["Cookie_Name"];
}
protected void SetResponseCookie()
{
if (b_IsNewCookie)
{
HttpContext.Current.Response.Cookies.Remove("Cookie_Name");
_ResponseCookie = new HttpCookie("Cookie_Name");
DateTime dtNow = DateTime.Now;
TimeSpan tsMinute = new TimeSpan(0, 2, 0, 0);
_ResponseCookie.Expires = dtNow + tsMinute;
_ResponseCookie["UserRole"] = UserRole;
_ResponseCookie["UserName"] = UserName;
HttpContext.Current.Response.Cookies.Add(_ResponseCookie);
b_IsNewCookie = false;
}
}
}
更多精彩内容其他人还在看

使用UserControl做网站导航条的思路 分析

使用UserControl做网站导航条的思路 分析
收藏 0 赞 0 分享

ASP.NET中使用AspnetAccessProvider

ASP.NET中使用AspnetAccessProvider
收藏 0 赞 0 分享

asp.net下实现URL重写技术的代码

asp.net下实现URL重写技术的代码
收藏 0 赞 0 分享

为大家经常为md5加密过的常用admin,admin888,0000密码

为大家经常为md5加密过的常用admin,admin888,0000密码
收藏 0 赞 0 分享

利用MS AJAX注册Javascript命名空间并创建类

利用MS AJAX注册Javascript命名空间并创建类
收藏 0 赞 0 分享

asp.net下gridview 批量删除的实现方法第1/3页

asp.net下gridview 批量删除的实现方法
收藏 0 赞 0 分享

用CSS实现图片倾斜 只支持IE

用CSS实现图片倾斜 只支持IE
收藏 0 赞 0 分享

asp.net(c#)中取得文件物理路径

asp.net(c#)中取得文件物理路径
收藏 0 赞 0 分享

垃圾代码二三行 ASPX小马

垃圾代码二三行 ASPX小马
收藏 0 赞 0 分享

.NET 2.0获取配置文件AppSettings和ConnectionStrings节数据的方法

.NET 2.0获取配置文件AppSettings和ConnectionStrings节数据的方法
收藏 0 赞 0 分享
查看更多