c语言sscanf函数的用法是什么
269
2023-01-26
java必懂的冷知识点之Base64加密与解密
为了安全地进行数据传输,就需要对数据进行加密与解密操作,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="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); //输出明文
}
}
程序执行结果:
d3d3Lm1sZG4uY24=(密文)
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 data=Base64.getEncoder().encode(data); //重复加密 return new String(data); //返回加密后的内容 } public static String decode(String str) { byte data[]=str.getBytes(); //获取加密内容 for(int x=0;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("mldn.cn"); System.out.println(StringUtil.dehttp://code(str)); } } 本程序基于Base64类的功能实现了一个自定义加密与解密程序,为了保证加密后的数据安全,采用的盐值格式为“盐值{原始数据}”,同时利用多次加密的形式确保了密文数据的可靠性。在实际开发中只要不对外公布盐值内容和加密次数就可以在较为安全的环境下进行数据传输.
data=Base64.getEncoder().encode(data); //重复加密
return new String(data); //返回加密后的内容
}
public static String decode(String str) {
byte data[]=str.getBytes(); //获取加密内容
for(int x=0;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("mldn.cn"); System.out.println(StringUtil.dehttp://code(str)); } } 本程序基于Base64类的功能实现了一个自定义加密与解密程序,为了保证加密后的数据安全,采用的盐值格式为“盐值{原始数据}”,同时利用多次加密的形式确保了密文数据的可靠性。在实际开发中只要不对外公布盐值内容和加密次数就可以在较为安全的环境下进行数据传输.
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("mldn.cn");
System.out.println(StringUtil.dehttp://code(str));
}
}
本程序基于Base64类的功能实现了一个自定义加密与解密程序,为了保证加密后的数据安全,采用的盐值格式为“盐值{原始数据}”,同时利用多次加密的形式确保了密文数据的可靠性。在实际开发中只要不对外公布盐值内容和加密次数就可以在较为安全的环境下进行数据传输.
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~