IUserTokenProvider가 등록되지 않았습니다.
최근에 Asp.Net Identity Core
신청서 1.0을 2.0으로 업데이트했습니다 .
시도하고 싶었던 새로운 기능 GenerateEmailConfirmationToken
등이 있습니다.
내가 사용하고 이 기준으로 프로젝트를.
사용자가 등록을 시도하면 Register의 Post 메소드 실행 중에 오류가 발생합니다.
private readonly UserManager<ApplicationUser> _userManager;
public ActionResult Register(RegisterViewModel model)
{
if (ModelState.IsValid)
{
var ifUserEXists = _userManager.FindByName(model.EmailId);
if (ifUserEXists == null) return View(model);
var confirmationToken = _userRepository.CreateConfirmationToken();//this is how i'm generating token currently.
var result = _userRepository.CreateUser(model,confirmationToken);
var user = _userManager.FindByName(model.EmailId);
if (result)
{
var code = _userManager.GenerateEmailConfirmationToken(user.Id);//error here
_userRepository.SendEmailConfirmation(model.EmailId, model.FirstName, confirmationToken);
//Information("An email is sent to your email address. Please follow the link to activate your account.");
return View("~/Views/Account/Thank_You_For_Registering.cshtml");
}
}
//Error("Sorry! email address already exists. Please try again with different email id.");
ModelState.AddModelError(string.Empty, Resource.AccountController_Register_Sorry__User_already_exists__please_try_again_);
return View(model);
}
라인에서
var code = _userManager.GenerateEmailConfirmationToken(user.Id);
다음과 같은 오류가 발생합니다.
No IUserTokenProvider is registered.
지금은 어떤 종류의 코드가 생성되는지보고 싶었습니다. ApplicationUser
클래스에서 상속 된 IdentityUser
클래스 를 변경해야 합니까?
아니면 그 기능이 작동하도록 변경해야 할 것이 있습니까?
UserTokenProvider
토큰을 생성 하려면을 지정해야합니다 .
using Microsoft.Owin.Security.DataProtection;
using Microsoft.AspNet.Identity.Owin;
// ...
var provider = new DpapiDataProtectionProvider("SampleAppName");
var userManager = new UserManager<ApplicationUser>(new UserStore<ApplicationUser>());
userManager.UserTokenProvider = new DataProtectorTokenProvider<ApplicationUser>(
provider.Create("SampleTokenName"));
이 문서도 읽어야합니다 : ASP.NET ID를 사용하여 응용 프로그램에 2 단계 인증 추가 .
In addition to the accepted answer, I'd like to add that this approach will not work in Azure Web-Sites, you'd get CryptographicException instead of a token.
To get it fixed for Azure, implement your own IDataProtector: see this answer
Slightly more detail in blog-post
In ASP.NET Core it's nowadays possible to configure a default service in the Startup.cs like this:
services.AddIdentity<ApplicationUser, IdentityRole>()
.AddDefaultTokenProviders();
There is no need to call the DpapiDataProtectionProvider
or anything like that. The DefaultTokenProviders() will take care of the call to GenerateEmailConfirmationToken from the UserManager.
My solution :
var provider = new DpapiDataProtectionProvider("YourAppName");
UserManager.UserTokenProvider = new DataProtectorTokenProvider<User, string>(provider.Create("UserToken"))
as IUserTokenProvider<User, string>;
My problem with this code solved.
Good luck friends.
In case anyone else makes the same mistake that I did. I tried to make a function like the one below and sure enough the error "No IUserTokenProvider is registered." was gone. However as soon as I tried to use the link generated from "callbackUrl" I got the error "Invalid token." In order for it to work you need to get the HttpContext UserManager. If you are using a standard ASP.NET MVC 5 application with individual user accounts you can do it like below..
Code that works:
public ActionResult Index()
{
//Code to create ResetPassword URL
var userManager = HttpContext.GetOwinContext().GetUserManager<ApplicationUserManager>();
var user = userManager.FindByName("useremail@gmail.com");
string code = userManager.GeneratePasswordResetToken(user.Id);
var callbackUrl = Url.Action("ResetPassword", "Account", new { userId = user.Id, code = code }, protocol: Request.Url.Scheme);
return View();
}
First try that does not work, No IUserTokenProvider is registered.
is gone but the URL created gets Invalid token.
.
public ActionResult NotWorkingCode()
{
//DOES NOT WORK - When used the error "Invalid token." will always trigger.
var provider = new DpapiDataProtectionProvider("ApplicationName");
var userManager = new ApplicationUserManager(new UserStore<ApplicationUser>(new ApplicationDbContext()));
userManager.UserTokenProvider = new DataProtectorTokenProvider<ApplicationUser>(provider.Create("ASP.NET Identity"));
var user = userManager.FindByName("useremail@gmail.com");
string code = userManager.GeneratePasswordResetToken(user.Id);
var callbackUrl = Url.Action("ResetPassword", "Account", new { userId = user.Id, code = code }, protocol: Request.Url.Scheme);
//DOES NOT WORK - When used the error "Invalid token." will always trigger.
return View();
}
As per pisker above
In startup.cs you can use
services.AddIdentity<ApplicationUser, IdentityRole>()
.AddDefaultTokenProviders();
In .net core 2.0 you may need to add to the startup.cs:
using Microsoft.AspNetCore.Identity;
This worked fine for me.
You may also be intrested in looking here:
How to implement a TokenProvider in ASP.NET Identity 1.1 nightly build?
to use the default token provider implementation from Microsoft.Identity.Owin package
I got the same error after updating Identity, and found that it was because I was using Unity.
See this question thread on the solution: Register IAuthenticationManager with Unity
Also below for quick reference:
Here is what I did to make Unity play nice with ASP.NET Identity 2.0:
I added the following to the
RegisterTypes
method in theUnityConfig
class:container.RegisterType<DbContext, ApplicationDbContext>(new HierarchicalLifetimeManager()); container.RegisterType<UserManager<ApplicationUser>>(new HierarchicalLifetimeManager()); container.RegisterType<IUserStore<ApplicationUser>, UserStore<ApplicationUser>>(new HierarchicalLifetimeManager()); container.RegisterType<AccountController>(new InjectionConstructor());
in IdentityConfig.cs, Add your twofactor option:
manager.RegisterTwoFactorProvider("PhoneCode", new PhoneNumberTokenProvider<ApplicationUser>
{
MessageFormat = "Your security code is {0}"
});
manager.RegisterTwoFactorProvider("EmailCode", new EmailTokenProvider<ApplicationUser>
{
Subject = "Security Code",
BodyFormat = "Your security code is {0}"
});
//config sms service
manager.SmsService = new Services.SMS();
var dataProtectionProvider = options.DataProtectionProvider;
if (dataProtectionProvider != null)
{
manager.UserTokenProvider = new DataProtectorTokenProvider<ApplicationUser>(dataProtectionProvider.Create("ASP.NET Identity"));
}
While modifying .NET Core's Identity files, I stumbled upon this error:
NotSupportedException: No IUserTwoFactorTokenProvider named 'Default' is registered.
The
Microsoft.AspNetCore.Identity.UserManager.GenerateUserTokenAsync
function couldn't generate a token because no provider was available upon registering a new user. This error has an easy fix though!
If you're like me, you changed AddDefaultIdentity
in the Startup.cs
file to AddIdentity
. I wanted to implement my own user that inherited from the base user. By doing this I lost the default token providers. The fix was to add them back with AddDefaultTokenProviders()
.
services.AddIdentity<User, UserRole>()
.AddEntityFrameworkStores<ApplicationDbContext>()
.AddDefaultTokenProviders();
After that fix, everything worked again!
참고URL : https://stackoverflow.com/questions/22629936/no-iusertokenprovider-is-registered
'programing' 카테고리의 다른 글
UNIX sort 명령은 어떻게 매우 큰 파일을 정렬 할 수 있습니까? (0) | 2020.08.25 |
---|---|
Maven없이 Nexus에 아티팩트 업로드 (0) | 2020.08.25 |
Java에서 SQL 문자열을 작성하는 가장 깨끗한 방법 (0) | 2020.08.25 |
std :: exception에서 상속해야합니까? (0) | 2020.08.25 |
gnupg :이 키가 명명 된 사용자에게 속해 있다는 보장이 없습니다. (0) | 2020.08.25 |