首頁 後端開發 C++ 如何使用 PBKDF2 在 .NET 中安全地散列密碼?

如何使用 PBKDF2 在 .NET 中安全地散列密碼?

Jan 23, 2025 pm 12:32 PM

How to Securely Hash Passwords in .NET Using PBKDF2?

使用當前最佳實踐在 .NET 中安全地雜湊密碼

在資料庫中儲存密碼時,使用雜湊演算法保護敏感資訊至關重要。加密方法不適用於此目的。 .NET 中最好的原生密碼雜湊演算法是 PBKDF2(基於密碼的金鑰衍生函數 2)。

使用 PBKDF2 進行密碼雜湊的逐步指南

步驟 1:產生鹽值

鹽值是一個隨機值,用來使每個密碼的雜湊值唯一。使用加密 PRNG(偽隨機數產生器)建立鹽值:

byte[] salt;
new RNGCryptoServiceProvider().GetBytes(salt = new byte[16]);
登入後複製

步驟 2:建立 PBKDF2 物件並計算雜湊值

實例化 Rfc2898DeriveBytes 類別並指定密碼、鹽值和所需的迭代次數(建議約 100,000 次):

var pbkdf2 = new Rfc2898DeriveBytes(password, salt, 100000);
byte[] hash = pbkdf2.GetBytes(20);
登入後複製

步驟 3:組合鹽值和密碼位元組以進行儲存

組合鹽值和密碼位元組以建立單一字串以供資料庫儲存:

byte[] hashBytes = new byte[36];
Array.Copy(salt, 0, hashBytes, 0, 16);
Array.Copy(hash, 0, hashBytes, 16, 20);
登入後複製

步驟 4:轉換為 Base64 字串以進行儲存

將組合的位元組編碼為 Base64 字串以儲存在資料庫中:

string savedPasswordHash = Convert.ToBase64String(hashBytes);
登入後複製

步驟 5:驗證使用者輸入的密碼

要驗證使用者輸入的密碼與儲存的雜湊值是否相符:

  • 從資料庫取得儲存的密碼雜湊值。
  • 從儲存的雜湊值中提取鹽值和雜湊位元組。
  • 使用使用者輸入的密碼和提取的鹽值計算新的雜湊值。
  • 將計算出的雜湊值與儲存的雜湊值進行比較。如果匹配,則密碼有效。
string savedPasswordHash = DBContext.GetUser(u => u.UserName == user).Password;

byte[] hashBytes = Convert.FromBase64String(savedPasswordHash);
byte[] salt = new byte[16];
Array.Copy(hashBytes, 0, salt, 0, 16);

var pbkdf2 = new Rfc2898DeriveBytes(password, salt, 100000);
byte[] hash = pbkdf2.GetBytes(20);

for (int i=0; i < 20; i++)
    if (hashBytes[i+16] != hash[i])
        throw new UnauthorizedAccessException();
登入後複製

注意:可以根據應用程式的效能要求調整迭代次數。通常建議最小值為 10,000。

以上是如何使用 PBKDF2 在 .NET 中安全地散列密碼?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章標籤

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

c語言函數格式字母大小寫轉換步驟 c語言函數格式字母大小寫轉換步驟 Mar 03, 2025 pm 05:53 PM

c語言函數格式字母大小寫轉換步驟

c語言函數返回值的類型有哪些?返回值是由什麼決定的? c語言函數返回值的類型有哪些?返回值是由什麼決定的? Mar 03, 2025 pm 05:52 PM

c語言函數返回值的類型有哪些?返回值是由什麼決定的?

Gulc:從頭開始建造的C庫 Gulc:從頭開始建造的C庫 Mar 03, 2025 pm 05:46 PM

Gulc:從頭開始建造的C庫

c語言函數的定義和調用規則是什麼 c語言函數的定義和調用規則是什麼 Mar 03, 2025 pm 05:53 PM

c語言函數的定義和調用規則是什麼

C標準模板庫(STL)如何工作? C標準模板庫(STL)如何工作? Mar 12, 2025 pm 04:50 PM

C標準模板庫(STL)如何工作?

c語言函數返回值在內存保存在哪裡? c語言函數返回值在內存保存在哪裡? Mar 03, 2025 pm 05:51 PM

c語言函數返回值在內存保存在哪裡?

distinct用法和短語分享 distinct用法和短語分享 Mar 03, 2025 pm 05:51 PM

distinct用法和短語分享

如何有效地使用STL(排序,查找,轉換等)的算法? 如何有效地使用STL(排序,查找,轉換等)的算法? Mar 12, 2025 pm 04:52 PM

如何有效地使用STL(排序,查找,轉換等)的算法?

See all articles