您好,登录后才能下订单哦!
密码登录
登录注册
点击 登录注册 即表示同意《亿速云用户服务条款》
在Java中,可以使用javax.crypto
包中的类和方法来实现字符串的加密和解密。以下是一个使用AES(高级加密标准)算法进行字符串加密和解密的示例:
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import java.nio.charset.StandardCharsets;
import java.util.Base64;
public class StringEncryptionDecryption {
public static void main(String[] args) throws Exception {
String originalString = "Hello, World!";
System.out.println("Original String: " + originalString);
// 加密
String encryptedString = encrypt(originalString, "mySecretKey123");
System.out.println("Encrypted String: " + encryptedString);
// 解密
String decryptedString = decrypt(encryptedString, "mySecretKey123");
System.out.println("Decrypted String: " + decryptedString);
}
public static String encrypt(String data, String key) throws Exception {
SecretKeySpec secretKey = new SecretKeySpec(key.getBytes(StandardCharsets.UTF_8), "AES");
Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
cipher.init(Cipher.ENCRYPT_MODE, secretKey);
byte[] encryptedBytes = cipher.doFinal(data.getBytes(StandardCharsets.UTF_8));
return Base64.getEncoder().encodeToString(encryptedBytes);
}
public static String decrypt(String encryptedData, String key) throws Exception {
SecretKeySpec secretKey = new SecretKeySpec(key.getBytes(StandardCharsets.UTF_8), "AES");
Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
cipher.init(Cipher.DECRYPT_MODE, secretKey);
byte[] decodedBytes = Base64.getDecoder().decode(encryptedData);
byte[] decryptedBytes = cipher.doFinal(decodedBytes);
return new String(decryptedBytes, StandardCharsets.UTF_8);
}
}
在这个示例中,我们使用了AES算法进行加密和解密。encrypt
方法接受一个字符串和一个密钥作为参数,返回加密后的字符串。decrypt
方法接受一个加密后的字符串和一个密钥作为参数,返回解密后的字符串。
注意:在实际应用中,建议使用更安全的加密模式(如CBC模式)和更强的密钥生成方法。此外,密钥管理也非常重要,不要将密钥硬编码在代码中,而是应该使用安全的方式存储和管理密钥。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。