1、什么是Base64
Base64是一种直接利用64位可打印字符来表示二进制数据的算法,是一种比较常见的加密算法。JDK1.8版本提供了java.util.Base64的工具类,使用Base64提供的2个内部类进行加解密操作。
数据加密:java.util.Base64.Encoder
,
对象获取方法:public static Base64.Encoder getEncoder()
数据加密处理:public byte[] encoder (byte[] src)。
数据解密:java.util.Base64.Decoder
,
对象获取方法:public static Base64.Decoder getDecoder(),
数据解密处理:public byte[] decoder (String src)。
2、Base64工具类的使用
- Base64加密与解密操作
import java.util.Base64;
/**
* Base64工具类
*/
public class Base64Test {
public static void main(String[] args) {
String msg = "www.taobao.com";
//数据加密
String ecMsg = new String(Base64.getEncoder().encode(msg.getBytes()));
System.out.println("密文:"+ecMsg);
//数据解密
String oldMsg = new String(Base64.getDecoder().decode(ecMsg));
System.out.println("明文:"+oldMsg);
}
}
运行效果图:
由于Base64属于JDK的原始实现,所以单纯的加密是不安全的,为了更加安全的加密操作,可利用“盐值(salt)”、自定义格式以及多次加密的方式来保证项目中的数据安全。
- 基于base64定义复杂加密与解密操作
import java.util.Base64;
/**
* 利用盐值和多次加密的方式
*/
public class Base64SaltTest {
private static final String SALT = "helloKitty";
private static final int REPEAT = 5;
/**
* 加密处理
* @param str 要加密的字符串,需要与盐值整合
* @return 加密后的数据
*/
public static String encode(String str) {
// 加盐处理
String temp = str + "{" + SALT + "}";
byte data[] = temp.getBytes();
for (int i = 0; i < REPEAT; i++) {
// 重复加密
data = Base64.getEncoder().encode(data);
}
return new String(data);
}
/**
* 解密处理
* @param str 需要解密的内容
* @return 解密后的原始数据
*/
public static String decode(String str) {
// 获取加密的内容
byte data[] = str.getBytes();
for (int i = 0; i < REPEAT; i++) {
// 多次解密
data = Base64.getDecoder().decode(data);
}
// 删除盐值格式
return new String(data).replaceAll("\\{\\w+\\}", "");
}
public static void main(String[] args) {
String str = encode("www.hello.com");
System.out.println("解密:" + decode(str));
}
}
运行结果:
采用盐值格式“盐值{原始数据}”和多次加密的形式可确保密文数据的可靠性。
-
在实际开发中,只要不对外公布
盐值内容
和
加密次数
就可以在比较安全的环境下进行数据传输。
版权声明:本文为qianfeifeio原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。