首页 > 代码库 > ASP.NET.Identity 加密算法
ASP.NET.Identity 加密算法
public static string HashPassword(string password) { if (password == null) { throw new ArgumentNullException("password"); } byte[] salt; byte[] bytes; using (Rfc2898DeriveBytes rfc2898DeriveBytes = new Rfc2898DeriveBytes(password, 16, 1000)) { salt = rfc2898DeriveBytes.Salt; bytes = rfc2898DeriveBytes.GetBytes(32); } byte[] array = new byte[49]; Buffer.BlockCopy(salt, 0, array, 1, 16); Buffer.BlockCopy(bytes, 0, array, 17, 32); return Convert.ToBase64String(array); } public static bool VerifyHashedPassword(string hashedPassword, string password) { if (hashedPassword == null) { return false; } if (password == null) { throw new ArgumentNullException("password"); } byte[] array = Convert.FromBase64String(hashedPassword); if (array.Length != 49 || array[0] != 0) { return false; } byte[] array2 = new byte[16]; Buffer.BlockCopy(array, 1, array2, 0, 16); byte[] array3 = new byte[32]; Buffer.BlockCopy(array, 17, array3, 0, 32); byte[] bytes; using (Rfc2898DeriveBytes rfc2898DeriveBytes = new Rfc2898DeriveBytes(password, array2, 1000)) { bytes = rfc2898DeriveBytes.GetBytes(32); } return ByteArraysEqual(array3, bytes); } private static bool ByteArraysEqual(byte[] a, byte[] b) { if (object.ReferenceEquals(a, b)) { return true; } if (a == null || b == null || a.Length != b.Length) { return false; } bool flag = true; for (int i = 0; i < a.Length; i++) { flag &= (a[i] == b[i]); } return flag; }
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。