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方法是一个演示用的占位符,你需要根据实际需求来实现获取嵌套角色列表的逻辑,例如从数据库中查询。

相关内容

热门资讯

本来有辅助"poke... 本来有辅助"pokemmo手机辅助软件"开挂(透视)辅助软件(玩家教你有挂功能);无需打开直接搜索加...
往昔有开挂"微信卡五... 往昔有开挂"微信卡五星辅助"开挂(透视)辅助透视(透视教程有挂规律) 【无需打开直接搜索加薇1367...
固有有辅助"福建兄弟... 固有有辅助"福建兄弟十三水有没有挂"开挂(透视)辅助下载(分享教程有挂教学);无需打开直接搜索加薇1...
本然有开挂"打两圈兴... 本然有开挂"打两圈兴化辅助"开挂(透视)辅助安装(揭秘教程有挂分享)《详细加薇136704302咨询...
从前有辅助"wepo... wepoker插件程序激活码是一款专注玩家量身打造的游戏记牌类型软件,在wepoker插件程序激活码...
往昔有辅助"小程序可... 往昔有辅助"小程序可以开挂吗"开挂(透视)辅助插件(高科技教程有挂教学)您好:小程序可以开挂吗这款游...
先前有开挂"钱塘十三... 钱塘十三水透视 无需打开直接搜索微信:136704302本司针对手游进行,选择我们的四大理由: 1、...
原先有开挂"决战卡五... 原先有开挂"决战卡五星游戏修改器"开挂(透视)辅助工具(软件教程有挂攻略)这是一款可以让一直输的玩家...
原先有开挂"暗宝破解... 原先有开挂"暗宝破解器"开挂(透视)辅助安装(黑科技教程有挂教程)【无需打开直接搜索加薇136704...
原生有开挂"湖南赣湘... 【亲,湖南赣湘互娱辅助脚本 这款游戏可以开挂的,确实是有挂的,很多玩家在这款湖南赣湘互娱辅助脚本中打...