赞
踩
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)。
- 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)”、自定义格式以及多次加密的方式来保证项目中的数据安全。
- 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));
- }
-
- }

运行结果:
采用盐值格式“盐值{原始数据}”和多次加密的形式可确保密文数据的可靠性。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。