【发布时间】:2020-01-23 16:15:55
【问题描述】:
我正在测试我在 ASP.NET Core 2.2 网站中使用的异常过滤器的功能。这是对 Microsoft.Identity.Web 示例 repo 中的 AuthorizeForScopesAttribute 类的轻微修改。
应该发生的是,当我们尝试从缓存中获取令牌时,它会抛出一个MsalUiRequiredException,它应该被过滤器捕获并强制重新验证。 TokenAcquisition 类 catches the exception 并抛出但过滤器永远不会捕获它。
为了测试 3.1,我创建了一个简单的 Blazor(服务器端)网站,添加了对 Microsoft.Identity.Web 的引用,并尝试调用 Microsoft Graph API;类似于this example。
ASP.NET Core 2.2 实现(Startup.cs):
services.AddMvc(options =>
{
var policy = new AuthorizationPolicyBuilder()
.RequireAuthenticatedUser()
.Build();
options.Filters.Add(new AuthorizeFilter(policy));
options.Filters.Add(new AuthorizeForScopesAttribute(new string[] {ScopeConstants.ScopeUserRead}));
});
ASP.NET Core 3.1 实现(Startup.cs):
services.AddControllersWithViews(options =>
{
var policy = new AuthorizationPolicyBuilder()
.RequireAuthenticatedUser()
.Build();
options.Filters.Add(new AuthorizeFilter(policy));
options.Filters.Add(new AuthorizeForScopesAttribute(new[] {ScopeConstants.ScopeUserRead}));
});
Microsoft.Identity.Web 的示例存储库依赖于使用属性装饰控制器,并且由于我将 Razor 页面用于我的 2.2 Web 应用程序和 Blazor(服务器端)用于我的 3.1 Web 应用程序,因此我不得不修改如下:
- 将
ExceptionFilterAttribute替换为IExceptionFilter - 添加了一个构造函数并在
Startup.cs中提供了Scopes属性 - 由于这不是抽象类的实现(现在使用接口),我删除了
OnException方法中的override语句,现在它只是public void OnException(ExceptionContext context)。
我一直在与维护回购协议的同事合作,但我们都对为什么它没有被触发感到困惑。由于 3.1 不再使用“UseMvc”语句,这甚至是正确的实现吗?据我所知it looks correct。
仅供参考:我意识到类名也不能反映这不再是一个属性的事实,但我现在只是保持名称不变。
【问题讨论】:
标签: c# asp.net-mvc asp.net-core