0

我有現成的老成員。NET網站的方式,現在我想要做的是轉換成新的MVC .NET身份的做法如何使用c#標識中的sql hasher密碼將加密密碼轉換爲純文本?

我已經提到這個Link,也是我得到了分貝轉換成新的身份數據庫這是完美的作品。

問題是新的身份不與我的舊密碼.i.e,而我想用我的密碼登錄它給我錯誤,密碼是不正確的。

編輯:添加代碼

這裏是應用程序用戶管理器代碼

public class ApplicationUserManager : UserManager<ApplicationUser> 
    { 
     public ApplicationUserManager(IUserStore<ApplicationUser> store) 
      : base(store) 
     { 
     } 

     //Added this constructor after reading microsoft blog https://docs.microsoft.com/en-us/aspnet/identity/overview/migrations/migrating-an-existing-website-from-sql-membership-to-aspnet-identity. 
     //except this constructor other codes are default which identity provides 
     public ApplicationUserManager() 
      : base(new UserStore<ApplicationUser>(new ApplicationDbContext())) 
     { 
      this.PasswordHasher = new SqlPasswordHasher(); 
     } 

     public static ApplicationUserManager Create(IdentityFactoryOptions<ApplicationUserManager> options, IOwinContext context) 
     { 
      var manager = new ApplicationUserManager(new UserStore<ApplicationUser>(context.Get<ApplicationDbContext>())); 
      // Configure validation logic for usernames 
      manager.UserValidator = new UserValidator<ApplicationUser>(manager) 
      { 
       AllowOnlyAlphanumericUserNames = false, 
       RequireUniqueEmail = true 
      }; 

      // Configure validation logic for passwords 
      manager.PasswordValidator = new PasswordValidator 
      { 
       RequiredLength = 6, 
       RequireNonLetterOrDigit = true, 
       RequireDigit = true, 
       RequireLowercase = true, 
       RequireUppercase = true, 
      }; 

      // Configure user lockout defaults 
      manager.UserLockoutEnabledByDefault = true; 
      manager.DefaultAccountLockoutTimeSpan = TimeSpan.FromMinutes(5); 
      manager.MaxFailedAccessAttemptsBeforeLockout = 5; 

      // Register two factor authentication providers. This application uses Phone and Emails as a step of receiving a code for verifying the user 
      // You can write your own provider and plug it in here. 
      manager.RegisterTwoFactorProvider("Phone Code", new PhoneNumberTokenProvider<ApplicationUser> 
      { 
       MessageFormat = "Your security code is {0}" 
      }); 
      manager.RegisterTwoFactorProvider("Email Code", new EmailTokenProvider<ApplicationUser> 
      { 
       Subject = "Security Code", 
       BodyFormat = "Your security code is {0}" 
      }); 
      manager.EmailService = new EmailService(); 
      manager.SmsService = new SmsService(); 
      var dataProtectionProvider = options.DataProtectionProvider; 
      if (dataProtectionProvider != null) 
      { 
       manager.UserTokenProvider = 
        new DataProtectorTokenProvider<ApplicationUser>(dataProtectionProvider.Create("ASP.NET Identity")); 
      } 
      return manager; 
     } 
    } 

這裏是我的SQL密碼散列器代碼。

public class SqlPasswordHasher : PasswordHasher 
    { 
     public override string HashPassword(string password) 
     { 
      return base.HashPassword(password); 
     } 

     public override PasswordVerificationResult VerifyHashedPassword(string hashedPassword, string providedPassword) 
     { 
      string[] passwordProperties = hashedPassword.Split('|'); 
      if (passwordProperties.Length != 3) 
      { 
       return base.VerifyHashedPassword(hashedPassword, providedPassword); 
      } 
      else 
      { 
       string passwordHash = passwordProperties[0]; 
       int passwordformat = 1; 
       string salt = passwordProperties[2]; 
       if (String.Equals(EncryptPassword(providedPassword, passwordformat, salt), passwordHash, StringComparison.CurrentCultureIgnoreCase)) 
       { 
        return PasswordVerificationResult.SuccessRehashNeeded; 
       } 
       else 
       { 
        return PasswordVerificationResult.Failed; 
       } 
      } 
     } 

     //This is copied from the existing SQL providers and is provided only for back-compat. 
     private string EncryptPassword(string pass, int passwordFormat, string salt) 
     { 
      if (passwordFormat == 0) // MembershipPasswordFormat.Clear 
       return pass; 

      byte[] bIn = Encoding.Unicode.GetBytes(pass); 
      byte[] bSalt = Convert.FromBase64String(salt); 
      byte[] bRet = null; 

      if (passwordFormat == 1) 
      { // MembershipPasswordFormat.Hashed 
       HashAlgorithm hm = HashAlgorithm.Create("SHA1"); 
       if (hm is KeyedHashAlgorithm) 
       { 
        KeyedHashAlgorithm kha = (KeyedHashAlgorithm)hm; 
        if (kha.Key.Length == bSalt.Length) 
        { 
         kha.Key = bSalt; 
        } 
        else if (kha.Key.Length < bSalt.Length) 
        { 
         byte[] bKey = new byte[kha.Key.Length]; 
         Buffer.BlockCopy(bSalt, 0, bKey, 0, bKey.Length); 
         kha.Key = bKey; 
        } 
        else 
        { 
         byte[] bKey = new byte[kha.Key.Length]; 
         for (int iter = 0; iter < bKey.Length;) 
         { 
          int len = Math.Min(bSalt.Length, bKey.Length - iter); 
          Buffer.BlockCopy(bSalt, 0, bKey, iter, len); 
          iter += len; 
         } 
         kha.Key = bKey; 
        } 
        bRet = kha.ComputeHash(bIn); 
       } 
       else 
       { 
        byte[] bAll = new byte[bSalt.Length + bIn.Length]; 
        Buffer.BlockCopy(bSalt, 0, bAll, 0, bSalt.Length); 
        Buffer.BlockCopy(bIn, 0, bAll, bSalt.Length, bIn.Length); 
        bRet = hm.ComputeHash(bAll); 
       } 
      } 

      return Convert.ToBase64String(bRet); 
     } 
    } 

這裏是登錄方法在賬戶控制器

 [HttpPost] 
     [AllowAnonymous] 
     [ValidateAntiForgeryToken] 
     public async Task<ActionResult> Login(LoginViewModel model, string returnUrl) 
     { 
      if (!ModelState.IsValid) 
      { 
       return View(model); 
      } 
      // This doesn't count login failures towards account lockout 
      // To enable password failures to trigger account lockout, change to shouldLockout: true 
      var result = await SignInManager.PasswordSignInAsync(model.Email, model.Password, model.RememberMe, shouldLockout: false); 
      switch (result) 
      { 
       case SignInStatus.Success: 
        return RedirectToLocal(returnUrl); 
       case SignInStatus.LockedOut: 
        return View("Lockout"); 
       case SignInStatus.RequiresVerification: 
        return RedirectToAction("SendCode", new { ReturnUrl = returnUrl, RememberMe = model.RememberMe }); 
       case SignInStatus.Failure: 
       default: 
        ModelState.AddModelError("", "Invalid login attempt."); 
        return View(model); 
      } 
     } 

感謝您的幫助!

+0

您需要提供更多的信息比這 –

+0

@鬍子更新後的帖子和添加code.please讓我知道你是否需要更多。 –

+0

您是否也使用'SqlPasswordHasher'加入會員資格? – Alisson

回答

0

我得到了我自己的問題的解決方案。添加了將加密密碼轉換爲純文本的新方法。

問題是會員表密碼存儲在加密的格式,所以我們需要實現方法,可以加密密碼轉換成普通text.which作爲跟隨

using Microsoft.AspNet.Identity; 
using System; 
using System.IO; 
using System.Security.Cryptography; 
using System.Text; 
using System.Web.Security; 
namespace GS365.MVC.Helpers 
{ 
    public class SQLPasswordHasher : PasswordHasher 
    { 
     public override string HashPassword(string password) 
     { 
      return base.HashPassword(password); 
     } 

     public override PasswordVerificationResult VerifyHashedPassword(string hashedPassword, string providedPassword) 
     { 
      string[] passwordProperties = hashedPassword.Split('|'); 
      if (passwordProperties.Length != 3) 
      { 
       return base.VerifyHashedPassword(hashedPassword, providedPassword); 
      } 
      else 
      { 
       string password = passwordProperties[0]; 
       int passwordformat = Convert.ToInt16(passwordProperties[1]); 
       if (passwordformat == 0 || passwordformat == 1) //Password type :0=Clear and 1=Hashed 
       { 
        string salt = passwordProperties[2]; 
        if (String.Equals(EncryptPassword(providedPassword, passwordformat, salt), password, StringComparison.CurrentCultureIgnoreCase)) 
        { 
         return PasswordVerificationResult.SuccessRehashNeeded; 
        } 
        else 
        { 
         return PasswordVerificationResult.Failed; 
        } 
       } 
       else if (passwordformat == 2)//Password type : 2=Encrypted 
       { 
        SqlMembershipProviderHelper sqlmembershipproviderhelper = new SqlMembershipProviderHelper(); 
        var existingPassword = sqlmembershipproviderhelper.GetClearTextPassword(password); 
        if (String.Equals(existingPassword, providedPassword, StringComparison.CurrentCultureIgnoreCase)) 
        { 
         return PasswordVerificationResult.SuccessRehashNeeded; 
        } 
        else 
        { 
         return PasswordVerificationResult.Failed; 
        } 
       } 
       return PasswordVerificationResult.Failed; 
      } 
     } 

     //This is copied from the existing SQL providers and is provided only for back-compat. 
     private string EncryptPassword(string pass, int passwordFormat, string salt) 
     { 
      if (passwordFormat == 0) // MembershipPasswordFormat.Clear 
       return pass; 

      byte[] bIn = Encoding.Unicode.GetBytes(pass); 
      byte[] bSalt = Convert.FromBase64String(salt); 
      byte[] bRet = null; 

      if (passwordFormat == 1) 
      { // MembershipPasswordFormat.Hashed 
       HashAlgorithm hm = HashAlgorithm.Create("SHA1"); 
       if (hm is KeyedHashAlgorithm) 
       { 
        KeyedHashAlgorithm kha = (KeyedHashAlgorithm)hm; 
        if (kha.Key.Length == bSalt.Length) 
        { 
         kha.Key = bSalt; 
        } 
        else if (kha.Key.Length < bSalt.Length) 
        { 
         byte[] bKey = new byte[kha.Key.Length]; 
         Buffer.BlockCopy(bSalt, 0, bKey, 0, bKey.Length); 
         kha.Key = bKey; 
        } 
        else 
        { 
         byte[] bKey = new byte[kha.Key.Length]; 
         for (int iter = 0; iter < bKey.Length;) 
         { 
          int len = Math.Min(bSalt.Length, bKey.Length - iter); 
          Buffer.BlockCopy(bSalt, 0, bKey, iter, len); 
          iter += len; 
         } 
         kha.Key = bKey; 
        } 
        bRet = kha.ComputeHash(bIn); 
       } 
       else 
       { 
        byte[] bAll = new byte[bSalt.Length + bIn.Length]; 
        Buffer.BlockCopy(bSalt, 0, bAll, 0, bSalt.Length); 
        Buffer.BlockCopy(bIn, 0, bAll, bSalt.Length, bIn.Length); 
        bRet = hm.ComputeHash(bAll); 
       } 
      } 
      return Convert.ToBase64String(bRet); 
     } 
    } 

    public class SqlMembershipProviderHelper : SqlMembershipProvider 
    { 
     /// <summary> 
     /// Used for decrypt password into plain text from encrypted type password 
     /// </summary> 
     /// <param name="encryptedPwd"></param> 
     /// <returns></returns> 
     public string GetClearTextPassword(string encryptedPwd) 
     { 
      byte[] encodedPassword = Convert.FromBase64String(encryptedPwd); 
      byte[] bytes = this.DecryptPassword(encodedPassword); 
      if (bytes == null) 
      { 
       return null; 
      } 
      return Encoding.Unicode.GetString(bytes, 0x10, bytes.Length - 0x10); 
     } 
    } 
}