abp授权原理

PermissionRequirement

 public class PermissionRequirement : AuthorizationHandler<PermissionRequirement>, IAuthorizationRequirement
 {
     public string PermissionName { get; set; }

     public PermissionRequirement(string permissionName)
     {
         PermissionName = permissionName;
     }

     protected override async Task HandleRequirementAsync(AuthorizationHandlerContext context, PermissionRequirement requirement)
     {
         // 获取用户权限
         var userPermissions = PermissionService.GetPermissions(context.User.Identity?.Name);
         if (userPermissions != null && userPermissions.Contains(requirement.PermissionName))
         {
             context.Succeed(requirement);
         }
     }
 }

PermissionAuthorizationPolicyProvider

public class PermissionAuthorizationPolicyProvider : DefaultAuthorizationPolicyProvider, IAuthorizationPolicyProvider
{
    public PermissionAuthorizationPolicyProvider(IOptions<AuthorizationOptions> options) : base(options)
    {
    }

    public override async Task<AuthorizationPolicy?> GetPolicyAsync(string policyName)
    {
        var policy = await base.GetPolicyAsync(policyName);
        if (policy != null)
        {
            return policy;
        }

        var builder = new AuthorizationPolicyBuilder();
        builder.AddRequirements(new PermissionRequirement(policyName));
        return builder.Build();
    }
}

PermissionService

public class PermissionService
{
    public static List<string> GetPermissions(string? name)
    {
        return new List<string>
        {
            "auth1",
            "auth2",
        };
    }
}

使用

builder.Services.AddTransient<IAuthorizationPolicyProvider, PermissionAuthorizationPolicyProvider>();

[Authorize("auth1")]
public IActionResult Privacy()
{
    return View();
}
posted @   pojianbing  阅读(12)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
点击右上角即可分享
微信分享提示