Rumah >Java >javaTutorial >Cara Menyulitkan Kata Laluan dengan Selamat dalam Fail Konfigurasi: Bagaimana Dengan Kunci?

Cara Menyulitkan Kata Laluan dengan Selamat dalam Fail Konfigurasi: Bagaimana Dengan Kunci?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-11-12 16:17:01656semak imbas

How to Securely Encrypt Passwords in Configuration Files: What About the Key?

Cara Menyulitkan Kata Laluan dengan Selamat dalam Fail Konfigurasi

Menyulitkan kata laluan yang disimpan dalam fail konfigurasi adalah penting untuk melindungi data sensitif. Berikut ialah pendekatan yang boleh dipercayai menggunakan Penyulitan Berasaskan Kata Laluan (PBE) dalam Java:

PBE membolehkan anda menyulitkan dan menyahsulit data menggunakan kata laluan. Ia melibatkan memulakan "javax.crypto.Cipher" dengan algoritma "AES/CBC/PKCS5Padding" dan mendapatkan semula kunci daripada "javax.crypto.SecretKeyFactory" dengan algoritma "PBKDF2WithHmacSHA512".

import java.security.AlgorithmParameters;
import java.security.GeneralSecurityException;
import java.security.spec.IvParameterSpec;
import java.util.Base64;
import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.PBEKeySpec;
import javax.crypto.spec.SecretKeySpec;

public class SecureConfigFile {
    // Encrypt the original password using a password-protected key
    private static String encrypt(String originalPassword, SecretKeySpec key) {
        ...
    }

    // Decrypt the encrypted password using the same password-protected key
    private static String decrypt(String encryptedPassword, SecretKeySpec key) {
        ...
    }

    // Create a password-protected key using PBKDF2WithHmacSHA512
    private static SecretKeySpec createSecretKey(char[] password, byte[] salt) {
        ...
    }
}

Sekali anda mempunyai kata laluan yang disulitkan, anda boleh menyimpannya dengan selamat dalam fail konfigurasi anda. Apabila anda perlu mengakses kata laluan, hanya gunakan kata laluan yang sama untuk menyahsulitnya.

Menyimpan Kata Laluan Utama

Cabaran utama terletak pada menyimpan kata laluan yang digunakan untuk melindungi kata laluan yang disulitkan. Semasa menyimpannya dalam fail sumber dengan kekeliruan adalah pilihan, ia terdedah kepada penemuan. Sebagai alternatif, anda boleh memberikan kata laluan sebagai sifat sistem apabila memulakan proses Java (-DpropertyProtectionPassword=...), tetapi ini juga mempunyai had keselamatan.

Akhirnya, mendapatkan kata laluan utama kekal sebagai cabaran, tetapi dengan menggunakan algoritma penyulitan yang kukuh dan amalan storan kunci selamat, anda boleh meningkatkan perlindungan data sensitif dalam fail konfigurasi dengan ketara.

Atas ialah kandungan terperinci Cara Menyulitkan Kata Laluan dengan Selamat dalam Fail Konfigurasi: Bagaimana Dengan Kunci?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn