MVC中Authorize权限请教

zmn817 2013-05-30 11:25:03
Authorize(Roles="Admins")
这句指定了该Action只能被Admins角色访问使用,在我的数据库中没有对用户进行分类角色,也没有Roles表,那写这个有什么意义?我想该Action被管理员用户访问,在我的数据库中是不是要添加Roles表?或者使用我数据库中的自己定义的角色表?也就是说Roles可以不可以修改成我数据库中的角色表或者用户表?
请大神赐教~
...全文
157 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
  • 打赏
  • 举报
回复
你可以根据需要自行添加相关的表,只要在后台能够得到当前用户对应的权限或者角色即可 如果有权限控制的,那么用户登录的时候,必然包含该用户是属于哪个角色的,有哪些权限 例如Session中包含了角色信息,那么就可以在如下方法中加入判断
protected override bool AuthorizeCore(HttpContextBase httpContext)
        {
            
            if (httpContext.Session["UserInfo"] == null)
                //return base.AuthorizeCore(httpContext);
                return false;

            //string currentRole = GetRole(httpContext.User.Identity.Name);
            string currentRole = (httpContext.Session["UserInfo"] as User).RoleName;

            if (currentRole == null)
                return false;

            if (Roles.Contains(currentRole))
                return true;
            
            //return base.AuthorizeCore(httpContext);
            return false;
        }

62,074

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧