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);
}
}
- Bouncy Castle: Bouncy Castle 是一个流行的第三方加密库,提供了许多加密算法和密码学工具。要使用 Bouncy Castle,您需要将其添加到项目的类路径中。以下是一个简单的 Bouncy Castle AES 加密和解密示例:
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 加密和解密操作。实际应用中,您可能需要根据需求选择合适的加密算法、密钥长度和填充模式。同时,为了确保数据安全,您还需要妥善保管密钥和敏感信息。