http://www.sufeinet.com/plugin.php?id=keke_group

苏飞论坛

 找回密码
 马上注册

QQ登录

只需一步,快速开始

分布式系统框架(V2.0) 轻松承载百亿数据,千万流量!讨论专区 - 源码下载 - 官方教程

HttpHelper爬虫框架(V2.7-含.netcore) HttpHelper官方出品,爬虫框架讨论区 - 源码下载 - 在线测试和代码生成

HttpHelper爬虫类(V2.0) 开源的爬虫类,支持多种模式和属性 源码 - 代码生成器 - 讨论区 - 教程- 例子

查看: 1961|回复: 0

[其他] asp.net中使用基于角色role的Forms验证

[复制链接]
发表于 2013-7-1 15:21:17 | 显示全部楼层 |阅读模式
根目录web.config
<authentication mode="Forms">
                        <forms name="loginApp" loginUrl="~/Navigation.aspx">
                        </forms>
                </authentication>
Navigation.aspx代码
if (string.IsNullOrEmpty(User.Identity.Name))
                {
                    Response.Write("<script language = javascript>window.parent.parent.location.href='Index.aspx'</script>");
                }
                else
                {
                    JSHelper.Alert("对不起,您没有权限访问该页面!", this.Page);
                }
权限web.config
  <!--系统维护-->
  <location path="systemmanage">
    <system.web>
      <authorization>
        <allow roles="系统管理员"/>
        <deny users="*"/>
      </authorization>
    </system.web>
  </location>
Global.asax代码
HttpCookie authCookie = Context.Request.Cookies[FormsAuthentication.FormsCookieName];
                     FormsAuthenticationTicket authTicket = FormsAuthentication.Decrypt(authCookie.Value);//解密
                     string[] roles = authTicket.UserData.Split(new char[] { ';' });//根据存入时的格式分解;
                     Context.User = new System.Security.Principal.GenericPrincipal(Context.User.Identity, roles);//存到HttpContext.User中
现在的问题是 通过角色不能实现权限功能,比如web.config我允许系统管理员管理页面,但是无效,通过用户名就可以,请问是哪里错了?



1. 开通SVIP会员,免费下载本站所有源码,不限次数据,不限时间
2. 加官方QQ群,加官方微信群获取更多资源和帮助
3. 找站长苏飞做网站、商城、CRM、小程序、App、爬虫相关、项目外包等点这里
您需要登录后才可以回帖 登录 | 马上注册

本版积分规则

QQ|手机版|小黑屋|手机版|联系我们|关于我们|广告合作|苏飞论坛 ( 豫ICP备18043678号-2)

GMT+8, 2024-5-3 13:44

© 2014-2021

快速回复 返回顶部 返回列表