国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > .NET > 正文

asp.net 基于forms驗證的目錄角色權限的實現

2024-07-10 13:18:28
字體:
來源:轉載
供稿:網友
但是我在使用過程中,發現針對角色的控制并不是那么容易,通過在網上查找資料,終于解決這個問題。下面將主要的注意事項列出來。
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, "http://www.survivalescaperooms.com/");//建立身份驗證票對象
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;


大致弄清這三點,就可以了。
代碼打包
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宜宾县| 孟州市| 沈阳市| 五原县| 曲麻莱县| 西乌珠穆沁旗| 岳西县| 新疆| 安泽县| 富裕县| 庆云县| 赤水市| 平安县| 和龙市| 张家界市| 大同市| 方山县| 徐闻县| 广丰县| 阿拉善右旗| 龙井市| 咸宁市| 娱乐| 临颍县| 米脂县| 翁源县| 施甸县| 濮阳市| 怀集县| 梁山县| 建宁县| 项城市| 赤峰市| 麻阳| 青田县| 晋宁县| 左云县| 沭阳县| 攀枝花市| 延寿县| 安图县|