代碼 復制代碼 代碼 " /> 亚洲精品中文字,亚洲激情自拍,欧美夫妻性生活视频

色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

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

但是我在使用過程中,發現針對角色的控制并不是那么容易,通過在網上查找資料,終于解決這個問題。下面將主要的注意事項列出來。
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;

大致弄清這三點,就可以了。
代碼打包

AspNet技術asp.net 基于forms驗證的目錄角色權限的實現,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 长海县| 临潭县| 广汉市| 仲巴县| 东光县| 东兴市| 乌鲁木齐县| 阿勒泰市| 姚安县| 三河市| 乌拉特后旗| 四会市| 紫阳县| 荣昌县| 即墨市| 留坝县| 庆阳市| 五莲县| 布尔津县| 敦煌市| 富源县| 镇赉县| 罗山县| 三明市| 肇庆市| 庐江县| 两当县| 璧山县| 红河县| 武汉市| 光山县| 石景山区| 灯塔市| 福贡县| 石门县| 英吉沙县| 安宁市| 漾濞| 丽水市| 肇庆市| 福泉市|