.NET Core 使用 MongoDb 配置 OpenIddict

Gio*_*ung 1 c# mongodb .net-core openiddict

对于我的 REST Api,我想使用 OpenIddict 身份验证方案。作为数据库,我使用 MongoDb。我已经安装了所有必要的依赖项。所有依赖项都有最新版本。

在我的 Startup.cs 中,我现在想注册 OpenIddict。在第一步中做这个(就像在文档中一样)

services.AddDbContext<UserDbContext>(options =>
{
    options.UseOpenIddict<ObjectId>();
});
Run Code Online (Sandbox Code Playgroud)

就在options.UseOpenIddict<ObjectId>();我收到以下错误:

'DbContextOptionsBuilder' does not contain a definition for 'UseOpenIddict' and no accessible extension method 'UseOpenIddict' accepting a first argument of type 'DbContextOptionsBuilder' could be found(are you missing a using directive or an assembly reference?)
Run Code Online (Sandbox Code Playgroud)

这是CS1061错误。

我正在使用所有指令。我已经谷歌了很多。我发现的唯一一件事是您需要安装所需的软件包,但我安装了它们。(在我遵循的教程的解决方案文件中是完全相同的)

有谁知道如何解决这个问题?

Gio*_*ung 5

问题在于一个包覆盖了该UseOpenIddict方法。我已经卸载了该软件包并重写了一些代码,因为该软件包不是必需的。是不兼容的包。

更新

感谢Kévin Chalet评论

我将我的身份配置重写为

services.AddIdentityMongoDbProvider<UserEntity, UserRoleEntity>(mongo =>
{
    mongo.ConnectionString = _databaseUri;
});
Run Code Online (Sandbox Code Playgroud)

这现在非常适合我。

更新 2

我已经在谷歌上搜索了更多,但没有找到有关如何正确实施 OpenIddict 和 MongoDb 的任何解决方案。对于刚刚开始以下内容的人可能会有所帮助。我的 OpenIddict/身份验证/授权使用以下配置运行良好:

启动文件

配置服务:

services.AddIdentityMongoDbProvider<UserEntity, UserRoleEntity>(mongo = >{
    mongo.ConnectionString = _databaseUri;
});

services.Configure<IdentityOptions>(options = >{
    options.ClaimsIdentity.UserNameClaimType = OpenIdConnectConstants.Claims.Name;
    options.ClaimsIdentity.UserIdClaimType = OpenIdConnectConstants.Claims.Subject;
    options.ClaimsIdentity.RoleClaimType = OpenIdConnectConstants.Claims.Role;
});

services.AddAuthentication(options = >{
    options.DefaultScheme = OpenIddictValidationDefaults.AuthenticationScheme;
});

services
    .AddOpenIddict()
    .AddCore(options = >{
        options.UseMongoDb()
            .UseDatabase(new MongoClient(_databaseUri)
            .GetDatabase(_database));
    }).AddServer(options = >{
        options.SetAccessTokenLifetime(TimeSpan.FromDays(5));
    
        options.UseMvc();
    
        options.EnableTokenEndpoint("/api/token");
    
        options.EnableUserinfoEndpoint("/api/userinfo");
    
        options.AllowPasswordFlow()
            .AllowRefreshTokenFlow();
    
        options.AcceptAnonymousClients();
    }).AddValidation();

services.AddAuthorization(options = >{
    options.DefaultPolicy = new AuthorizationPolicyBuilder()
                .AddAuthenticationSchemes(OpenIddictValidationDefaults.AuthenticationScheme)
                .RequireAuthenticatedUser()
                .Build();
});
Run Code Online (Sandbox Code Playgroud)

配置:

app.UseAuthentication();

app.UseCors("AllowBrowserApp");

app.UseRouting();

app.UseAuthorization();
Run Code Online (Sandbox Code Playgroud)

注意:注册身份验证和授权的位置很重要。身份验证在此之前app.UseRouting(),授权在此之后。否则它不会工作。如果您使用 Visual Studio,它将显示给您。

用户实体.cs

public class UserEntity : MongoUser
{
    public string Firstname { get; set; }

    public string Lastname { get; set; }
}
Run Code Online (Sandbox Code Playgroud)

如果需要,您可以添加更多属性。

用户角色实体.cs

public class UserRoleEntity : MongoRole
{
    public UserRoleEntity() : base() { }

    public UserRoleEntity(string roleName) : base(roleName) { }
}
Run Code Online (Sandbox Code Playgroud)