SM4
public class Test {
public static void main(String[] args) {
String skey = "abcd1234567890ab";
SymmetricCrypto sm4 = SmUtil.sm4(skey.getBytes());
String enBase64Data = sm4.encryptBase64("你好呀");
String decryptStr = sm4.decryptStr(enBase64Data);
System.out.println("sm4加密后:" + enBase64Data);
System.out.println("sm4解密后:" + decryptStr);
}
}
AES
import cn.hutool.core.util.HexUtil;
import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
import java.nio.charset.StandardCharsets;
public class AESUtils {
private static final String AES_ALGORITHM = "AES";
private static final String AES_MODE = "AES/CBC/PKCS5Padding";
private static final String AES_KEY = "1234567890123456";
private static final String AES_IV = "abcdefghijklmnop";
public static String encrypt(String data) throws Exception {
SecretKeySpec secretKeySpec = new SecretKeySpec(AES_KEY.getBytes(), AES_ALGORITHM);
IvParameterSpec ivParameterSpec = new IvParameterSpec(AES_IV.getBytes());
Cipher cipher = Cipher.getInstance(AES_MODE);
cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec, ivParameterSpec);
byte[] encryptedData = cipher.doFinal(data.getBytes(StandardCharsets.UTF_8));
return new String(HexUtil.encodeHex(encryptedData));
}
public static String decrypt(String encryptedData) throws Exception {
byte[] decodedData = HexUtil.decodeHex(encryptedData);
SecretKeySpec secretKeySpec = new SecretKeySpec(AES_KEY.getBytes(), AES_ALGORITHM);
IvParameterSpec ivParameterSpec = new IvParameterSpec(AES_IV.getBytes());
Cipher cipher = Cipher.getInstance(AES_MODE);
cipher.init(Cipher.DECRYPT_MODE, secretKeySpec, ivParameterSpec);
byte[] decryptedData = cipher.doFinal(decodedData);
return new String(decryptedData, StandardCharsets.UTF_8);
}
public static void main(String[] args) throws Exception {
String data = "Hello World";
String encryptedData = encrypt(data);
System.out.println("加密后的数据:" + encryptedData);
String decryptedData = decrypt(encryptedData);
System.out.println("解密后的数据:" + decryptedData);
}
}