Java 提供了許多庫和工具來處理數據加密。以下是一些常用的 Java 加密庫和方法:
Java Cryptography Extension (JCE): JCE 提供了加密和解密算法,如 AES、DES、RSA 等。要使用 JCE,您需要獲取相應的密鑰庫和密鑰管理器。
Java Cryptography Architecture (JCA): JCA 是 Java 加密框架的基礎,提供了加密、解密、密鑰生成和密鑰協商等操作。JCA 支持多種加密算法,如 AES、DES、RSA、DSA 等。
Java Cryptography Integration (JCI): JCI 是一個用于集成第三方加密算法的庫,如 Bouncy Castle、OpenSSL 等。要使用 JCI,您需要將相應的庫添加到項目的類路徑中。
javax.crypto 包: 這個包提供了加密和解密操作的類,如 Cipher、SecretKey、KeyGenerator、Mac 等。以下是一個簡單的 AES 加密和解密示例:
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import java.util.Base64;
public class AESExample {
public static void main(String[] args) throws Exception {
// 生成 AES 密鑰
KeyGenerator keyGenerator = KeyGenerator.getInstance("AES");
keyGenerator.init(128);
SecretKey secretKey = keyGenerator.generateKey();
// 加密數據
Cipher encryptCipher = Cipher.getInstance("AES");
encryptCipher.init(Cipher.ENCRYPT_MODE, secretKey);
byte[] encryptedData = encryptCipher.doFinal("Hello, World!".getBytes());
String encryptedDataBase64 = Base64.getEncoder().encodeToString(encryptedData);
System.out.println("Encrypted data: " + encryptedDataBase64);
// 解密數據
Cipher decryptCipher = Cipher.getInstance("AES");
decryptCipher.init(Cipher.DECRYPT_MODE, secretKey);
byte[] decryptedData = decryptCipher.doFinal(Base64.getDecoder().decode(encryptedDataBase64));
String decryptedString = new String(decryptedData);
System.out.println("Decrypted data: " + decryptedString);
}
}
import org.bouncycastle.jce.provider.BouncyCastleProvider;
import org.bouncycastle.util.encoders.Base64;
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import java.security.Security;
public class BCExample {
public static void main(String[] args) throws Exception {
// 添加 Bouncy Castle 提供者
Security.addProvider(new BouncyCastleProvider());
// 生成 AES 密鑰
KeyGenerator keyGenerator = KeyGenerator.getInstance("AES", "BC");
keyGenerator.init(128);
SecretKey secretKey = keyGenerator.generateKey();
// 加密數據
Cipher encryptCipher = Cipher.getInstance("AES/ECB/PKCS5Padding", "BC");
encryptCipher.init(Cipher.ENCRYPT_MODE, secretKey);
byte[] encryptedData = encryptCipher.doFinal("Hello, World!".getBytes());
String encryptedDataBase64 = Base64.toBase64String(encryptedData);
System.out.println("Encrypted data: " + encryptedDataBase64);
// 解密數據
Cipher decryptCipher = Cipher.getInstance("AES/ECB/PKCS5Padding", "BC");
decryptCipher.init(Cipher.DECRYPT_MODE, secretKey);
byte[] decryptedData = decryptCipher.doFinal(Base64.parseBase64String(encryptedDataBase64));
String decryptedString = new String(decryptedData);
System.out.println("Decrypted data: " + decryptedString);
}
}
這些示例展示了如何使用 Java 進行基本的 AES 加密和解密操作。實際應用中,您可能需要根據需求選擇合適的加密算法、密鑰長度和填充模式。同時,為了確保數據安全,您還需要妥善保管密鑰和敏感信息。