我有一个使用Identity进行用户身份验证的ASP.NET Core 3.1应用。我想配置身份以允许来自不同提供商(如Facebook和Twitter)的外部登录。
我在数据库中存储了多个外部登录提供程序。可以使用IAuthProvider
服务访问这些记录。
[使用ConfigureServices()
方法配置应用程序时,我想解析IAuthProvider
的实例以从数据库中获取所有可用记录,然后添加所需的登录提供程序。
下面是我的代码,我在IAuthProvider
方法中正在努力解决如何解析ConfigureServices()
实例。也许有更好的方法来配置或推迟配置提供程序,直到稍后,但不确定如何以及在何处配置服务器。
如何创建IAuthProvider
的实例并正确配置身份提供者?
public void ConfigureServices(IServiceCollection services)
{
services.AddDbContext<ApplicationDbContext>(options =>
{
options.UseMySql(Configuration.GetConnectionString("MySqlServerConnection"));
});
services.AddScoped<IAuthProvider, AuthProvider>();
// other services
var providers = // Here I somehow need to resolve an instance of IAuthProvider;
AuthenticationBuilder authBuilder = services.AddAuthentication();
foreach (var provider in providers.All())
{
if (provider.Name == ExternalLoginProvider.Facebook)
{
authBuilder.AddFacebook(options =>
{
options.AppId = provider.AppId;
options.AppSecret = provider.Secret;
});
}
if (provider.Name == ExternalLoginProvider.Twitter)
{
authBuilder.AddTwitter(options =>
{
options.ConsumerKey = provider.AppId;
options.ConsumerSecret = provider.Secret;
});
}
// Other providers
}
}
[我看到您的代码已经注册了IAuthProvider的实现,您可以简单地调用servcice.GetService()来获取AuthProvider的实例。我不明白以这种方式使用不同的身份验证提供程序的意思,根据此document,您可以像这样在链中添加不同的身份验证提供程序:
services.AddAuthentication()
.AddMicrosoftAccount(microsoftOptions => { ... })
.AddGoogle(googleOptions => { ... })
.AddTwitter(twitterOptions => { ... })
.AddFacebook(facebookOptions => { ... });
为什么单独添加它们?