使用我自己的角色而不是 Active Directory 组?-6ren"> 使用我自己的角色而不是 Active Directory 组?-我知道以下 Razor 代码适用于 AD 组。 但是,我需要从 json 文件授予权限。在 json 文件中,它定义了, { "WindowsUserName1" : [ "My own gr-6ren">
gpt4 book ai didi

asp.net - 使用我自己的角色而不是 Active Directory 组?

转载 作者:行者123 更新时间:2023-12-02 00:12:27 25 4
gpt4 key购买 nike

我知道以下 Razor 代码适用于 AD 组。

<AuthorizeView  Roles="AD_Group1, AD_Group2">

</AuthorizeView>

但是,我需要从 json 文件授予权限。在 json 文件中,它定义了,

{
"WindowsUserName1" : [ "My own group 1", "My own group 2" ],
"WindowsUserName2" : [ "My own group 2", "My own group 3" ],
....
}

如何让<AuthorizeView>使用自定义分组?

最佳答案

您可以定义自定义策略来为用户组创建授权规则:

构建自定义需求:

public class UserGroupsRequirement : IAuthorizationRequirement
{
public string[] Groups { get; }

public UserGroupsRequirement(string[] groups)
{
Groups = groups;
}
}

为需求创建一个处理程序。这个需要继承自AuthorizationHandler<T>其中 T是要处理的要求:

public class UserGroupsHandler : AuthorizationHandler<UserGroupsRequirement>
{
protected override Task HandleRequirementAsync(AuthorizationHandlerContext context, UserGroupsRequirement requirement)
{

var username = context.User.Claims.FirstOrDefault(c=>c.Type==ClaimTypes.Name).Value;

var groups = requirement.Groups;

//read json file and find user's groups and check whether groups inlcude in required groups.

if (true)
{
context.Succeed(requirement);
}

return Task.CompletedTask;
}
}

注册策略:

services.AddAuthorization(config =>
{
config.AddPolicy("UserInGroupsAdmin", policy =>
policy.Requirements.Add(new UserGroupsRequirement(new string[] { "group1"})));
});

services.AddSingleton<IAuthorizationHandler, UserGroupsHandler>();

并且您可以更新 AuthorizeView 组件以使用策略:

<AuthorizeView  Policy="UserInGroupsAdmin">
<p>You can only see this if you're an admin or superuser.</p>
</AuthorizeView>

关于asp.net - <AuthorizeView Roles ="...."> 使用我自己的角色而不是 Active Directory 组?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58531500/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com