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 用户管理
相关文章
.NET或.NET Core Web APi基于tus协议实现断点续传的示例
这篇文章主要介绍了.NET或.NET Core Web APi基于tus协议实现断点续传的示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-11-11
ASP.NET Core 6.0 基于模型验证的数据验证功能
这篇文章主要介绍了ASP.NET Core 6.0 基于模型验证的数据验证,本文描述的数据验证方案,是基于官方的模型验证(Model validation),需要的朋友可以参考下2022-07-07
asp.net实现在XmlTextWriter中写入一个CDATA的方法
这篇文章主要介绍了asp.net实现在XmlTextWriter中写入一个CDATA的方法,结合实例形式分析了XmlTextWriter写入CDATA的步骤与相关实现技巧,需要的朋友可以参考下2016-04-04
ASP.NET导出Excel打开时提示:与文件扩展名指定文件不一致解决方法
ASP.NET导出Excel,打开时提示“您尝试打开文件'XXX.xls'的格式与文件扩展名指定文件不一致” 很是郁闷,于是搜集了一些解决方法,感兴趣的朋友可以了解下2013-01-01


最新评论