如何在Identity 3中实现IUserTokenProvider时生成令牌?

时间:2016-05-07 12:34:02

标签: asp.net-web-api asp.net-core asp.net-identity access-token asp.net-core-1.0

我正在尝试实施 IUserTokenProvider 接口以在Identity系统中注册并进一步用于身份验证。 为什么是令牌身份验证,因为我使用身份3 Asp Net Core 中编写 Web Api 服务器。 障碍是我不知道如何生成令牌。 IUserTokenProvider 有两种我需要的方法:1。生成令牌2.验证令牌。 我在里面写什么?什么是算法?

public class UserTokenProvider : IUserTokenProvider<AppUser>
{
    public Task<bool> CanGenerateTwoFactorTokenAsync(UserManager<AppUser> manager, AppUser user)
    {
        throw new NotImplementedException();
    }

    public Task<string> GenerateAsync(string purpose, UserManager<AppUser> manager, AppUser user)
    {
        /* here logic to generate token */
        string result = "generated token";
        return Task.FromResult(result);
    }
    public Task<bool> ValidateAsync(string purpose, string token, UserManager<AppUser> manager, AppUser user)
    {
        /* validating token */
        if (token == "generated token")
            return Task.FromResult(true);
        else return Task.FromResult(false);
    }
}

在StartUp类的 ConfigureServices 方法中,我注册了我的提供者:

services.AddIdentity<AppUser, IdentityRole>(options => {
            options.User.RequireUniqueEmail = true;
        })
            .AddEntityFrameworkStores<UserDbContext>()
            .AddTokenProvider<UserTokenProvider>("AuthToken") 
            .AddDefaultTokenProviders();

1 个答案:

答案 0 :(得分:3)

正如其他SO post中所述,IUserTokenProvider与令牌身份验证完全无关。

我建议您阅读这些其他问题,以获取有关如何在ASP.NET Core中发布自己的访问权限的更多信息: