当前位置:   article > 正文

Base64加密与解密使用(+拓展:盐值法)_base64加盐

base64加盐

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加密与解密操作
  1. import java.util.Base64;
  2. /**
  3. * Base64工具类
  4. */
  5. public class Base64Test {
  6. public static void main(String[] args) {
  7. String msg = "www.taobao.com";
  8. //数据加密
  9. String ecMsg = new String(Base64.getEncoder().encode(msg.getBytes()));
  10. System.out.println("密文:"+ecMsg);
  11. //数据解密
  12. String oldMsg = new String(Base64.getDecoder().decode(ecMsg));
  13. System.out.println("明文:"+oldMsg);
  14. }
  15. }

运行效果图:

由于Base64属于JDK的原始实现,所以单纯的加密是不安全的,为了更加安全的加密操作,可利用“盐值(salt)”、自定义格式以及多次加密的方式来保证项目中的数据安全。

  • 基于base64定义复杂加密与解密操作
  1. import java.util.Base64;
  2. /**
  3. * 利用盐值和多次加密的方式
  4. */
  5. public class Base64SaltTest {
  6. private static final String SALT = "helloKitty";
  7. private static final int REPEAT = 5;
  8. /**
  9. * 加密处理
  10. * @param str 要加密的字符串,需要与盐值整合
  11. * @return 加密后的数据
  12. */
  13. public static String encode(String str) {
  14. // 加盐处理
  15. String temp = str + "{" + SALT + "}";
  16. byte data[] = temp.getBytes();
  17. for (int i = 0; i < REPEAT; i++) {
  18. // 重复加密
  19. data = Base64.getEncoder().encode(data);
  20. }
  21. return new String(data);
  22. }
  23. /**
  24. * 解密处理
  25. * @param str 需要解密的内容
  26. * @return 解密后的原始数据
  27. */
  28. public static String decode(String str) {
  29. // 获取加密的内容
  30. byte data[] = str.getBytes();
  31. for (int i = 0; i < REPEAT; i++) {
  32. // 多次解密
  33. data = Base64.getDecoder().decode(data);
  34. }
  35. // 删除盐值格式
  36. return new String(data).replaceAll("\\{\\w+\\}", "");
  37. }
  38. public static void main(String[] args) {
  39. String str = encode("www.hello.com");
  40. System.out.println("解密:" + decode(str));
  41. }
  42. }

运行结果:

采用盐值格式“盐值{原始数据}”和多次加密的形式可确保密文数据的可靠性。

  • 在实际开发中,只要不对外公布盐值内容加密次数就可以在比较安全的环境下进行数据传输。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小丑西瓜9/article/detail/202946
推荐阅读
相关标签
  

闽ICP备14008679号