如何使用 PBKDF2 在 Java 中安全地散列密碼?
如何安全地散列密碼進行儲存
以明文形式儲存密碼會帶來重大的安全風險。為了保護敏感數據,在儲存密碼之前對其進行雜湊處理至關重要。此過程涉及將明文密碼轉換為固定大小的加密格式,該格式不可逆且破解的計算成本很高。 Java 為密碼雜湊提供了強大的工具,確保了使用者憑證的安全性。
使用PBKDF2 進行安全密碼雜湊
Java 6 中的SunJCE 庫引入了PBKDF2(密碼-基於密鑰派生函數2),這是一種行業標準的密碼雜湊演算法。它旨在透過結合隨機鹽和高計算成本來防止暴力攻擊和彩虹表攻擊。
使用 PBKDF2 實作密碼雜湊
- 建立鹽:產生隨機鹽以防止使用預先計算的彩虹表。
- 對密碼進行雜湊處理:利用 PBKDF2 演算法從密碼和鹽中導出雜湊值。
- 儲存雜湊密碼:將鹽和雜湊密碼安全地保存在資料庫中。
驗證登入期間的密碼
使用者登入時in:
- 擷取鹽:取得與使用者帳戶相關聯的鹽。
- 對提交的密碼進行雜湊處理:使用檢索到的鹽計算提交密碼的雜湊值。
- 比較雜湊值:檢查計算的雜湊值是否與儲存的雜湊密碼相符。如果匹配,則密碼正確。
密碼雜湊範例程式碼
import java.security.NoSuchAlgorithmException; import java.security.SecureRandom; import java.security.spec.InvalidKeySpecException; import java.security.spec.KeySpec; import java.util.Arrays; import java.util.Base64; import java.util.regex.Matcher; import java.util.regex.Pattern; import javax.crypto.SecretKeyFactory; import javax.crypto.spec.PBEKeySpec; public class PasswordAuthentication { public String hash(char[] password) { byte[] salt = new byte[SIZE / 8]; random.nextBytes(salt); byte[] dk = pbkdf2(password, salt, 1 << cost); byte[] hash = new byte[salt.length + dk.length]; System.arraycopy(salt, 0, hash, 0, salt.length); System.arraycopy(dk, 0, hash, salt.length, dk.length); return ID + cost + '$' + enc.encodeToString(hash); } public boolean authenticate(char[] password, String token) { Matcher m = layout.matcher(token); if (!m.matches()) throw new IllegalArgumentException("Invalid token format"); int iterations = iterations(Integer.parseInt(m.group(1))); byte[] hash = Base64.getUrlDecoder().decode(m.group(2)); byte[] salt = Arrays.copyOfRange(hash, 0, SIZE / 8); byte[] check = pbkdf2(password, salt, iterations); int zero = 0; for (int idx = 0; idx < check.length; ++idx) zero |= hash[salt.length + idx] ^ check[idx]; return zero == 0; } private byte[] pbkdf2(char[] password, byte[] salt, int iterations) { KeySpec spec = new PBEKeySpec(password, salt, iterations, SIZE); try { SecretKeyFactory f = SecretKeyFactory.getInstance(ALGORITHM); return f.generateSecret(spec).getEncoded(); } catch (NoSuchAlgorithmException ex) { throw new IllegalStateException("Missing algorithm: " + ALGORITHM, ex); } catch (InvalidKeySpecException ex) { throw new IllegalStateException("Invalid SecretKeyFactory", ex); } } }
結論
以上是如何使用 PBKDF2 在 Java 中安全地散列密碼?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

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

公司安全軟件導致部分應用無法正常運行的排查與解決方法許多公司為了保障內部網絡安全,會部署安全軟件。 ...

在使用MyBatis-Plus或其他ORM框架進行數據庫操作時,經常需要根據實體類的屬性名構造查詢條件。如果每次都手動...

系統對接中的字段映射處理在進行系統對接時,常常會遇到一個棘手的問題:如何將A系統的接口字段有效地映�...

將姓名轉換為數字以實現排序的解決方案在許多應用場景中,用戶可能需要在群組中進行排序,尤其是在一個用...

在使用IntelliJIDEAUltimate版本啟動Spring...

Java對象與數組的轉換:深入探討強制類型轉換的風險與正確方法很多Java初學者會遇到將一個對象轉換成數組的�...

電商平台SKU和SPU表設計詳解本文將探討電商平台中SKU和SPU的數據庫設計問題,特別是如何處理用戶自定義銷售屬...

在使用TKMyBatis進行數據庫查詢時,如何優雅地獲取實體類變量名以構建查詢條件,是一個常見的難題。本文將針...
