Java加密函数的使用方法及示例
Java提供了多种加密函数来实现数据的加密和解密操作。常用的加密函数主要包括对称加密和非对称加密。
1. 对称加密
对称加密算法是指使用相同的密钥进行加密和解密的算法,比如常用的AES和DES加密算法。使用对称加密算法进行加密和解密的步骤如下:
(1)创建Cipher对象:使用Cipher类的getInstance方法创建一个Cipher对象,同时传入加密算法的名称。
Cipher cipher = Cipher.getInstance("AES");
(2)初始化Cipher对象:使用Cipher对象的init方法初始化Cipher对象,设置加密或解密模式以及密钥。
cipher.init(Cipher.ENCRYPT_MODE, key);
(3)执行加密或解密操作:使用Cipher对象的doFinal方法执行加密或解密操作,传入需要加密或解密的数据。
byte[] encryptedData = cipher.doFinal(data);
下面是一个使用AES加密算法进行数据加密和解密的示例代码:
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import java.util.Base64;
public class SymmetricEncryptionExample {
public static void main(String[] args) throws Exception {
String data = "Hello, World!";
// 生成密钥
KeyGenerator keyGenerator = KeyGenerator.getInstance("AES");
keyGenerator.init(128);
SecretKey secretKey = keyGenerator.generateKey();
byte[] keyBytes = secretKey.getEncoded();
SecretKeySpec keySpec = new SecretKeySpec(keyBytes, "AES");
// 加密
Cipher cipher = Cipher.getInstance("AES");
cipher.init(Cipher.ENCRYPT_MODE, keySpec);
byte[] encryptedData = cipher.doFinal(data.getBytes());
String encryptedDataStr = Base64.getEncoder().encodeToString(encryptedData);
System.out.println("Encrypted data: " + encryptedDataStr);
// 解密
cipher.init(Cipher.DECRYPT_MODE, keySpec);
byte[] decryptedData = cipher.doFinal(Base64.getDecoder().decode(encryptedDataStr));
String decryptedDataStr = new String(decryptedData);
System.out.println("Decrypted data: " + decryptedDataStr);
}
}
2. 非对称加密
非对称加密算法是指使用公钥和私钥进行加密和解密的算法,比如常用的RSA加密算法。使用非对称加密算法进行加密和解密的步骤如下:
(1)创建Cipher对象:使用Cipher类的getInstance方法创建一个Cipher对象,同时传入加密算法的名称。
Cipher cipher = Cipher.getInstance("RSA");
(2)初始化Cipher对象:使用Cipher对象的init方法初始化Cipher对象,设置加密或解密模式以及密钥。
cipher.init(Cipher.ENCRYPT_MODE, publicKey);
(3)执行加密或解密操作:使用Cipher对象的doFinal方法执行加密或解密操作,传入需要加密或解密的数据。
byte[] encryptedData = cipher.doFinal(data);
下面是一个使用RSA非对称加密算法进行数据加密和解密的示例代码:
import javax.crypto.Cipher;
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.PrivateKey;
import java.security.PublicKey;
import java.util.Base64;
public class AsymmetricEncryptionExample {
public static void main(String[] args) throws Exception {
String data = "Hello, World!";
// 生成密钥对
KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("RSA");
keyPairGenerator.initialize(2048);
KeyPair keyPair = keyPairGenerator.generateKeyPair();
PublicKey publicKey = keyPair.getPublic();
PrivateKey privateKey = keyPair.getPrivate();
// 加密
Cipher cipher = Cipher.getInstance("RSA");
cipher.init(Cipher.ENCRYPT_MODE, publicKey);
byte[] encryptedData = cipher.doFinal(data.getBytes());
String encryptedDataStr = Base64.getEncoder().encodeToString(encryptedData);
System.out.println("Encrypted data: " + encryptedDataStr);
// 解密
cipher.init(Cipher.DECRYPT_MODE, privateKey);
byte[] decryptedData = cipher.doFinal(Base64.getDecoder().decode(encryptedDataStr));
String decryptedDataStr = new String(decryptedData);
System.out.println("Decrypted data: " + decryptedDataStr);
}
}
以上就是Java加密函数的使用方法及示例。根据具体需求选择对称加密还是非对称加密算法,并根据算法的要求生成密钥,然后使用Cipher对象进行加密和解密操作即可。
