Python语言技术文档

微信小程序技术文档

php语言技术文档

jsp语言技术文档

asp语言技术文档

C#/.NET语言技术文档

html5/css技术文档

javascript

点击排行

您现在的位置:首页 > 技术文档 > C#/.NET技巧

asp.net 基于forms验证的目录角色权限的实现

来源:中文源码网    浏览:142 次    日期:2024-05-12 01:57:15
【下载文档:  asp.net 基于forms验证的目录角色权限的实现.txt 】


asp.net 基于forms验证的目录角色权限的实现
但是我在使用过程中,发现针对角色的控制并不是那么容易,通过在网上查找资料,终于解决这个问题。下面将主要的注意事项列出来。1、配置文件中,角色的allow项要放在deny项的前面,users要配置为*,而不是? 代码 复制代码 代码如下: //这个在前 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; 大致弄清这三点,就可以了。 代码打包

相关内容