本文介绍了如何在AddOpenIdConnect事件(OnTokenValiated)中注入服务?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我需要编写需要ConfigureServices
才能完全执行的业务逻辑。
OnTokenValidated
与ConfigureServices
本身的位置错误。
AddOpenIdConnect
中间件有什么替代方案,以便我可以Success
完全灵活地调用以使用插入的服务?
services.AddAuthentication(options =>
{
options.DefaultScheme = "cookie";
//...
})
.AddOpenIdConnect("oidc", options =>
{
options.Authority = "https://localhost:5001";
/....
options.Scope.Add("offline_access");
options.Events.OnTokenValidated = async n =>
{
//Need other services which will only
//get injected once ConfigureServices method has fully executed.
};
}
参考:为什么 https://docs.microsoft.com/en-us/aspnet/core/fundamentals/dependency-injection?view=aspnetcore-5.0#ASP0000
推荐答案
若要解析OnTokenValidated
事件处理程序内的服务,可以使用TokenValidatedContext.HttpContext.RequestServices
:
Events =
{
OnTokenValidated = async context =>
{
var someService = context.HttpContext.RequestServices.GetRequiredService<ISomeService>();
var result = await someService.DoSomethingAsync();
// a custom callback
}
}
这篇关于如何在AddOpenIdConnect事件(OnTokenValiated)中注入服务?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!