ASP.NET MVC 中实现基于角色的权限控制的处理方法
更新时间:2013年03月20日 15:42:53 作者:
在ASP.NET MVC中,通过使用其所提供的内置
[Authorize]
public ActionResult Index()
标记的方式,可以实现所标记的ACTION必须是认证用户才能访问;
通过使用
[Authorize(Users="username")]
的方式,可以实现所标记的ACTION必须是某个具体的用户才能访问,以上两种方式使用起来非常方便,在NeedDinner示例程序中已有具休的实现过程,
但是,我们在实际的应用中所使用的大都是基于角色(Roles)的认证方式,NeedDinner中却未给出,本文给出具体实现(基于ASP.NET Forms验证)过程:
step 1
在完成UserName和Password认证后,向客户端写入认证Cookie
代码
复制代码 代码如下:
FormsAuthenticationTicket authTicket = new FormsAuthenticationTicket(
1,
userName,
DateTime.Now,
DateTime.Now.AddMinutes(20),
false,
"admin"//写入用户角色
);
string encryptedTicket = FormsAuthentication.Encrypt(authTicket);
System.Web.HttpCookie authCookie = new System.Web.HttpCookie(FormsAuthentication.FormsCookieName, encryptedTicket);
System.Web.HttpContext.Current.Response.Cookies.Add(authCookie);
step 2
在Global.asax.cs文件中加入以下代码,用于在用户登陆网站时读取Cookie
代码
复制代码 代码如下:
protected void Application_AuthenticateRequest(Object sender, EventArgs e)
{
HttpCookie authCookie = Context.Request.Cookies[FormsAuthentication.FormsCookieName];
if (authCookie == null || authCookie.Value == "")
{
return;
}
FormsAuthenticationTicket authTicket = null;
try
{
authTicket = FormsAuthentication.Decrypt(authCookie.Value);
}
catch
{
return;
}
string[] roles = authTicket.UserData.Split(new char[] { ';' });
if (Context.User != null)
{
Context.User = new System.Security.Principal.GenericPrincipal(Context.User.Identity, roles);
}
}
step 3
这样以来,就可以使用实现以下效果
复制代码 代码如下:
[Authorize(Roles="admin")]
public ActionResult Index(int ? page)
您可能感兴趣的文章:
- asp.net membership 密码重设
- asp.net 权限管理分析
- asp.net Forms身份验证和基于角色的权限访问
- 实例说明asp.net中的简单角色权限控制
- asp.net 基于forms验证的目录角色权限的实现
- 获取创建Membership的数据库创建脚本
- 一个基于Asp.Net MVC的权限方案
- asp.net+sqlserver实现的简单高效的权限设计示例
- asp.net BasePage类+Session通用用户登录权限控制
- Asp.net Mvc 身份验证、异常处理、权限验证(拦截器)实现代码
- ASP.NET通用权限验证的实现代码思路
- 初识 ASP.NET Membership 用户管理
相关文章
asp.net 根据汉字的拼音首字母搜索数据库(附 LINQ 调用方法)
我们经常需要使用拼音首字母来检索数据库,特别是应用于医院、商店等行业软件中。譬如搜索“zgr”就可以搜索所有包含“中国人”的记录。那么如果来实现才能即高效又方便呢?2010-04-04
最新评论