手机
当前位置:查字典教程网 >编程开发 >asp.net教程 >asp.net 基于forms验证的目录角色权限的实现
asp.net 基于forms验证的目录角色权限的实现
摘要:但是我在使用过程中,发现针对角色的控制并不是那么容易,通过在网上查找资料,终于解决这个问题。下面将主要的注意事项列出来。1、配置文件中,角色...

但是我在使用过程中,发现针对角色的控制并不是那么容易,通过在网上查找资料,终于解决这个问题。下面将主要的注意事项列出来。

1、配置文件中,角色的allow项要放在deny项的前面,users要配置为*,而不是?

代码

复制代码 代码如下:

<location path="Doctors">

<system.web>

<authorization>

<allow roles="doctors"/> //这个在前

<deny users="*"/>

</authorization>

</system.web>

</location>

2、将角色写入票据

代码

复制代码 代码如下:

string role="doctors";

FormsAuthenticationTicket Ticket = new FormsAuthenticationTicket(1, username, DateTime.Now, DateTime.Now.AddMinutes(30), false, role, "/");//建立身份验证票对象

string HashTicket = FormsAuthentication.Encrypt(Ticket);//加密序列化验证票为字符串

HttpCookie UserCookie = new HttpCookie(FormsAuthentication.FormsCookieName, HashTicket);

//生成Cookie

Response.Cookies.Add(UserCookie);//输出Cookie

Response.Redirect("");//重定向到用户申请的初始页面

3、身份票据并没有直接提供对role的直接支持,需要在Application_AuthenticateRequest中对role进行解析

代码

复制代码 代码如下:

string[] roles = authTicket.UserData.Split(new char[] { '|' });

FormsIdentity id = new FormsIdentity(authTicket);

System.Security.Principal.GenericPrincipal principal = new System.Security.Principal.GenericPrincipal(id, roles);

Context.User = principal;

大致弄清这三点,就可以了。

代码打包

【asp.net 基于forms验证的目录角色权限的实现】相关文章:

ASP.Net 图片存入数据库的实现代码

asp.net下出现其中的组件“访问被拒绝”的解决方法

asp.net ext treepanel 动态加载XML的实现方法

asp.net后台如何输出js脚本使用什么方法可以实现

asp.net中eval不能定义变量的问题的解决方法

asp.net(C#) 生成随机验证码的代码

asp.net 操作excel的实现代码

c# .net 生成图片验证码的代码

asp.net 日期函数 某月的第一天和最后一天的日期

asp.net验证码图片生成示例

精品推荐
分类导航