对称编码器 解密解密 工具类
程序员文章站
2024-03-14 14:25:04
...
当前加密解密方法可以使用在正式项目中,对不重要的数据进行加密。
使用中,请合理保存秘钥并定期或不定期更换秘钥,以对数据进行更好的隐私保护。
如果项目中不是对用户密码严格性要求,此方法可以做进一步改善,使用的密码验证中。
import java.security.SecureRandom;
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import sun.misc.BASE64Decoder;
import sun.misc.BASE64Encoder;
/**
* @author wangwei
* @version v1.0.0
* @description 加密 AES对称加密和解密
* @date 2019-01-09
*/
public class SymmetricEncoder {
/*
* 加密
*/
public static String AESEncode(String encodeRules,String content){
try {
KeyGenerator ******=KeyGenerator.getInstance("AES");
******.init(128, new SecureRandom(encodeRules.getBytes()));
SecretKey original_key=******.generateKey();
byte [] raw=original_key.getEncoded();
SecretKey key=new SecretKeySpec(raw, "AES");
Cipher cipher=Cipher.getInstance("AES");
cipher.init(Cipher.ENCRYPT_MODE, key);
byte [] byte_encode=content.getBytes("utf-8");
byte [] byte_AES=cipher.doFinal(byte_encode);
String AES_encode=new String(new BASE64Encoder().encode(byte_AES));
return AES_encode;
} catch (Exception e) {
e.printStackTrace();
}
return "";
}
/*
* 解密
*/
public static String AESDncode(String encodeRules,String content){
try {
KeyGenerator ******=KeyGenerator.getInstance("AES");
******.init(128, new SecureRandom(encodeRules.getBytes()));
SecretKey original_key=******.generateKey();
byte [] raw=original_key.getEncoded();
SecretKey key=new SecretKeySpec(raw, "AES");
Cipher cipher=Cipher.getInstance("AES");
cipher.init(Cipher.DECRYPT_MODE, key);
byte [] byte_content= new BASE64Decoder().decodeBuffer(content);
byte [] byte_decode=cipher.doFinal(byte_content);
String AES_decode=new String(byte_decode,"utf-8");
return AES_decode;
} catch (Exception e) {
e.printStackTrace();
}
return "";
}
}
上一篇: java sm4国密算法加密、解密
下一篇: 利用Filter实现服务之间的加密通讯