gpt4 book ai didi

.net - 即使方法标记为 AllowAnonymous,也会为无效 token 返回 401

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

使用 .Net 框架,Web Api。

我的 Controller 上有 [Authorize] 属性,某些端点上有 [AllowAnonymous]

我有几个允许匿名的端点,但如果用户通过身份验证则返回不同的(更多)数据。

如果用户拥有过期的 token ,他们目前会获得匿名版本的数据。

我想做的是,如果请求 header 中存在 token 并且 token 无效(通常是因为它已过期),我想返回 401,即使该方法被标记为 [AllowAnonymous]

(这将触发客户端获取新 token 并获取经过身份验证的数据,而不是静默地只获取数据的子集)

谢谢

编辑澄清:我正在寻找的是一个过滤器,它将检查 User.Identity.IsAuthenticated 是否为 false 但请求中有授权持有者 token ,过滤器应返回 401尽管该方法被标记为 [AllowAnonymous]

最佳答案

我通过重写 AuthorizeAttribute 来做到这一点。

public class AuthorizeCustomAttribute : System.Web.Http.AuthorizeAttribute
{

public override void OnAuthorization(System.Web.Http.Controllers.HttpActionContext actionContext)
{
if (actionContext == null)
{
throw new ArgumentNullException("actionContext");
}

if (SkipAuthorization(actionContext))
{
return;
}

if (!IsAuthorized(actionContext))
{
HandleUnauthorizedRequest(actionContext);
}
}

private static bool SkipAuthorization(System.Web.Http.Controllers.HttpActionContext actionContext)
{
//override default logic.
//If there is a authorization header, return unauthorized even if method is marked AllowAnonymous

System.Diagnostics.Contracts.Contract.Assert(actionContext != null);

if (actionContext.ActionDescriptor.GetCustomAttributes<System.Web.Http.AllowAnonymousAttribute>().Any()
|| actionContext.ControllerContext.ControllerDescriptor.GetCustomAttributes<System.Web.Http.AllowAnonymousAttribute>().Any())
{

if (actionContext.Request.Headers.Authorization == null) return true;
}
return false;
}
}

关于.net - 即使方法标记为 AllowAnonymous,也会为无效 token 返回 401,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62918147/

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