gpt4 book ai didi

c# - 如何使用 AuthorizationHandlerContext 在 ASP.NET Core 2 自定义基于策略的授权中访问当前的 HttpContext

转载 作者:可可西里 更新时间:2023-11-01 08:31:52 25 4
gpt4 key购买 nike

如何访问当前的 HttpContext 以检查 ASP.NET Core 2 中基于自定义策略的授权的 AuthorizationHandlerContext 中的路由和参数?

引用示例:Custom Policy-Based Authorization

最佳答案

你应该注入(inject)一个 IHttpContextAccessor 的实例进入您的 AuthorizationHandler

在您的 example 的上下文中,这可能类似于以下内容:

public class BadgeEntryHandler : AuthorizationHandler<EnterBuildingRequirement>
{
IHttpContextAccessor _httpContextAccessor = null;

public BadgeEntryHandler(IHttpContextAccessor httpContextAccessor)
{
_httpContextAccessor = httpContextAccessor;
}

protected override Task HandleRequirementAsync(
AuthorizationContext context,
EnterBuildingRequirement requirement)
{
HttpContext httpContext = _httpContextAccessor.HttpContext; // Access context here

if (context.User.HasClaim(c => c.Type == ClaimTypes.BadgeId &&
c.Issuer == "http://microsoftsecurity"))
{
context.Succeed(requirement);
return Task.FromResult(0);
}
}
}

您可能需要在您的 DI 设置中注册它(如果您的依赖项之一尚未注册),如下所示:

services.AddHttpContextAccessor();

关于c# - 如何使用 AuthorizationHandlerContext 在 ASP.NET Core 2 自定义基于策略的授权中访问当前的 HttpContext,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47809437/

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