当前位置:   article > 正文

Base64加密与解密---- ----java必懂的冷知识点_base64util.decode

base64util.decode

为了安全地进行数据传输,就需要对数据进行加密与解密操作,Base64就是Java提供的加密处理器。本博客主要讲解Base64工具类的使用以及加密和解密信息操作实现。

Base64是一种直接利用64个可打印字符来表示二进制数据的算法,也是网络传输中较为常见的一种加密算法。从JDK1.8版本开始提供java.util.Base64的工具类,同时提供了两个Base64的内部类实现数据加密与解密操作。

【数据加密】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[] decoer (String src)。

### 范例:实现Base64加密与解密操作

package cn.mldn.demo;
import java.util.Base64;
public class JavaAPIDemo{
      public static void main(String[] args) throws Exception{
         String msg="www.mldn.cn";            //原始内容
         String encMsg=new String(Base64.getEncoder().encode(msg.getBytes()));//数据加密
         System.out.println(encMsg);             //输出密文
         String oldMsg=new String(Base64.getDecoder().decode(encMsg));   //数据解密
         System.out.println(oldMsg); //输出明文
      }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

程序执行结果:
d3d3Lm1sZG4uY24=(密文)
www.mldn.cn(明文)

本程序直接利用Base64提供的方法获取了Base64.Encoder与Base64.Decoder实例化对象,并且对原始数据进行了加密与解密处理。但需要注意的是,由于Base64属于JDK的原始实现,所以单纯地加密是不安全的,此时为了获取更加安全的数据加密操作,可以利用盐值(salt)、自定义格式以及多次加密的方式来保证项目中的数据安全。

### 范例:基于Base64定义复杂加密与解密操作

package cn.mldn.demo;
import java.util.Base64;

class StringUtil
{
	private static final String SALT="mldnjava";  //公共的盐值
	private static final int REPEAT=5;     //加密次数
	
	public static String encode(String str) {       //加密处理		
										
		String temp=str+"{"+SALT+"}";				//盐值对外不公布
		byte data[]=temp.getBytes();				//将字符串变为字节数组
		for(int x=0;x<REPEAT;x++)
			data=Base64.getEncoder().encode(data);  //重复加密
		return new String(data);       //返回加密后的内容
	}
	
	public static String decode(String str) {
		byte data[]=str.getBytes();					//获取加密内容
		for(int x=0;x<REPEAT;x++)
			data=Base64.getDecoder().decode(data);  //多次解密
		return new String(data).replaceAll("\\{\\w+\\}","");  //删除盐值格式
	}
} 

public class JavaAPIDemo{
    public static void main(String[] args) throws Exception{
       String str=StringUtil.encode("www.mldn.cn");
       System.out.println(StringUtil.decode(str));
    }
    
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32

本程序基于Base64类的功能实现了一个自定义加密与解密程序,为了保证加密后的数据安全,采用的盐值格式为“盐值{原始数据}”,同时利用多次加密的形式确保了密文数据的可靠性。在实际开发中只要不对外公布盐值内容和加密次数就可以在较为安全的环境下进行数据传输.

感谢所有支持我的小伙伴,我们一起加油

在这里插入图片描述

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

闽ICP备14008679号