我目前正在学习 Blazor 客户端(WebAssembly),在查看授权时,我试图验证用户是否可以访问 URI 中的路径。
给定一个像http://localhost:1234/ {route}/resource这样的 URI
在页面上,我可以将路由映射到属性,但是如何在 AuthorizationHandler 中访问此值以验证 JWT 是否具有此值的声明?
我试图注入 RouteData 并且我试图通过 IHttpContextAccessor 访问 HttpContext 但那是空的。
这是我想要开始工作的课程
public class RouteDataAccessor : IRouteDataAccessor
{
private readonly RouteData _routeData;
public RouteDataAccessor(IHttpContextAccessor httpContextAccessor)
{
httpContextAccessor.NullCheck(nameof(httpContextAccessor));
httpContextAccessor.HttpContext.NullCheck(nameof(httpContextAccessor.HttpContext));
_routeData = httpContextAccessor.HttpContext.GetRouteData();
}
public bool TryGetData(string key, out string value)
{
value = null;
if (_routeData == null || !_routeData.Values.TryGetValue(key, out value))
{
return false;
}
return true;
}
}