ASP.NET Core授权对于嵌套角色不起作用
创始人
2024-09-16 00:30:42
0

在ASP.NET Core中,授权处理基于策略的。默认情况下,ASP.NET Core的授权系统不会通过递归查找嵌套角色来授权。如果需要支持嵌套角色的授权,可以自定义一个策略处理程序来实现。

下面是一个示例,演示如何自定义策略处理程序来支持嵌套角色的授权:

首先,创建一个自定义的策略处理程序(NestedRolesAuthorizationHandler.cs):

using Microsoft.AspNetCore.Authorization;
using System.Security.Claims;
using System.Threading.Tasks;

public class NestedRolesAuthorizationHandler : AuthorizationHandler
{
    protected override Task HandleRequirementAsync(AuthorizationHandlerContext context, RolesAuthorizationRequirement requirement)
    {
        if (context.User != null && context.User.Identity != null && context.User.Identity.IsAuthenticated)
        {
            // 获取用户的角色列表
            var roles = context.User.FindAll(ClaimTypes.Role).Select(c => c.Value).ToList();

            // 递归查找嵌套角色
            var nestedRoles = GetNestedRoles(requirement.AllowedRoles);
            
            // 检查用户的角色是否包含在嵌套角色列表中
            if (roles.Any(r => nestedRoles.Contains(r)))
            {
                context.Succeed(requirement);
            }
        }

        return Task.CompletedTask;
    }

    private List GetNestedRoles(IEnumerable roles)
    {
        var nestedRoles = new List();

        foreach (var role in roles)
        {
            // TODO: 根据角色获取嵌套角色列表,例如从数据库中查询
            // 将嵌套角色添加到nestedRoles列表中
        }

        return nestedRoles;
    }
}

然后,在Startup.cs文件的ConfigureServices方法中注册自定义的策略处理程序:

services.AddAuthorization(options =>
{
    options.AddPolicy("NestedRolesPolicy", policy =>
    {
        policy.Requirements.Add(new RolesAuthorizationRequirement());
    });
});

services.AddSingleton();

最后,在需要进行授权的地方使用自定义的策略:

[Authorize(Policy = "NestedRolesPolicy")]
public IActionResult MySecuredAction()
{
    // 只有拥有嵌套角色的用户才能访问该方法
    return View();
}

请注意,在示例代码中,GetNestedRoles方法是一个演示用的占位符,你需要根据实际需求来实现获取嵌套角色列表的逻辑,例如从数据库中查询。

相关内容

热门资讯

此事引发广泛关注!hhpoke... 此事引发广泛关注!hhpoker是内部控制吗,打哈儿麻将辅助下载,切实有辅助app(哔哩哔哩)1、每...
据权威媒体报道!hhpoker... 据权威媒体报道!hhpoker辅助挂下载,九游破解辅助插件,本来真的是有辅助工具(哔哩哔哩)1、每一...
网友热议!wepoker透视脚... 网友热议!wepoker透视脚本免费,约局吧辅助辅助外开挂,本来是真的有辅助方法(哔哩哔哩)1、约局...
据玩家消息!wepoker透视... 据玩家消息!wepoker透视脚本免费,禅游指尖四川作必弊,一直存在有辅助教程(哔哩哔哩)禅游指尖四...
记者获悉!hhpkoer辅助器... 记者获悉!hhpkoer辅助器,wepoker辅助软件视频,切实存在有辅助软件(哔哩哔哩)1、每一步...
近日!德州透视是真的假的,哥哥... 近日!德州透视是真的假的,哥哥打大a辅助,总是真的有辅助神器(哔哩哔哩)1、起透看视 德州透视是真的...
今日!hhpoker破解工具,... 今日!hhpoker破解工具,潮汕汇app辅助,其实有辅助方法(哔哩哔哩)1、实时潮汕汇app辅助透...
有玩家发现!pokemmo手机... 有玩家发现!pokemmo手机脚本辅助器,微乐兰州麻将小程序辅助,一直是真的有辅助攻略(哔哩哔哩)小...
昨日!wepoker透视版下载... 昨日!wepoker透视版下载,闲来辅助工具,确实是真的有辅助工具(哔哩哔哩)1、下载好闲来辅助工具...
有了最新消息!hhpoker有... 您好,杭州都莱到底有没有挂这款游戏可以开挂的,确实是有挂的,需要了解加去威信【136704302】很...