加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

asp.net-mvc – ASP.NET MVC 5 Identity 2.0,Windows Auth,具有

发布时间:2020-12-16 03:16:33 所属栏目:asp.Net 来源:网络整理
导读:我正在尝试创建一个使用 Windows身份验证但使用从用户模型中提取的角色的MVC5应用程序. 我已经搜索过高低的示例,但我能找到的唯一一个基于旧的ASP.NET身份框架. 有人关心我指向正确的方向吗?! 谢谢! 解决方法 所以我找到了解决这个问题的方法.我创建了一
我正在尝试创建一个使用 Windows身份验证但使用从用户模型中提取的角色的MVC5应用程序.

我已经搜索过高低的示例,但我能找到的唯一一个基于旧的ASP.NET身份框架.

有人关心我指向正确的方向吗?!

谢谢!

解决方法

所以我找到了解决这个问题的方法.我创建了一个自定义授权属性,用于检查角色的用户模型.

using System.Linq;
using System.Web;
using System.Web.Mvc;
using App.Models;
using System.Security.Claims;

namespace App.Extensions.Attributes
{
    public class AuthorizeUser : AuthorizeAttribute
    {
        Context context = new Context();

        protected override bool AuthorizeCore(HttpContextBase httpContext)
        {

            if (httpContext == null) 
                return false;

            string login = ClaimsPrincipal.Current.Claims.ElementAt(1).Value.Split('@')[0];
            string[] roles = base.Roles.Split(',');
            User user = context.Users.FirstOrDefault(u => u.Login == login);

            if (user == null)
                return false;
            else if (base.Roles == "")
                return true;
            else
                return roles.Contains(user.Role.ToString());
        }
    }
}

思考?

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读