在ASP.NET Core 2.2中,当配置了多个身份验证方案时,ChallengeResult的预期行为是将请求重定向到指定的身份验证方案进行认证。下面是一个包含代码示例的解决方法:
首先,需要在Startup.cs文件的ConfigureServices方法中配置身份验证方案。以下是一个示例:
public void ConfigureServices(IServiceCollection services)
{
// 添加身份验证服务
services.AddAuthentication()
.AddScheme("Scheme1", options => { })
.AddScheme("Scheme2", options => { });
// 添加MVC服务
services.AddMvc();
}
其中,Scheme1Handler和Scheme2Handler是自定义的身份验证方案处理程序,可以根据需要进行实现。
接下来,在控制器中使用ChallengeResult来触发身份验证。以下是一个示例:
[Authorize(AuthenticationSchemes = "Scheme1")]
public IActionResult ExampleAction()
{
// 验证Scheme1身份验证方案
return Challenge(new AuthenticationProperties { RedirectUri = "/Home/Index" });
}
在上面的示例中,[Authorize]特性指定了要使用Scheme1身份验证方案进行认证。在ExampleAction方法中,使用Challenge方法触发身份验证,并指定重定向的URL为"/Home/Index"。
当请求ExampleAction时,ASP.NET Core将检查当前用户的身份验证状态。如果用户未通过Scheme1身份验证方案认证,将重定向到相应的身份验证端点进行认证。