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 = https://www.yisu.com/ask/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 = https://www.yisu.com/ask/decryptCipher.doFinal(Base64.getDecoder().decode(encryptedDataBase64));"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 = https://www.yisu.com/ask/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 = https://www.yisu.com/ask/decryptCipher.doFinal(Base64.parseBase64String(encryptedDataBase64));"Decrypted data: " + decryptedString); } }
这些示例展示了如何使用 Java 进行基本的 AES 加密和解密操作。实际应用中,您可能需要根据需求选择合适的加密算法、密钥长度和填充模式。同时,为了确保数据安全,您还需要妥善保管密钥和敏感信息。