在写代码的时候经常用到加密的方法,加密算法一般分为以下几种
注:本文不做加密算法具体介绍,如果有兴趣可以搜索算法的详细介绍。
一、BASE64:这种也不算是加密的算法,只是根据一定的规则将内容转换成特定的字符串,一般不用于加密
二、对称加密:一般有DES、3DES、AES 均可使用
三、非对称加密:RSA、DSA 一般用于数据量不大的重要信息
四、单向加密:MD2、MD5、SHA、SHA-1、SHA-256、SHA-384、SHA-512 一般用于数据校验
这些算法API的实现在JDK中已经有了,但是在工作中还是可以看到同事用代码写出来具体转换的过程,感觉这是一个重复造轮子的事情,下面介绍一下直接调用java中调用相应的api来实现这些加密算法。
一:BASE64:
String str="测试";
BASE64Encoder baseEncoder=new BASE64Encoder();
String temp_str=baseEncoder.encode(str.getBytes("UTF-8"));
System.out.println("BASE64结果:"+temp_str);
String result="5rWL6K+V";
BASE64Decoder baseDecoder=new BASE64Decoder();
byte[] bb=baseDecoder.decodeBuffer(result);
System.out.println("BASE64解码:"+new String(bb,"utf-8"));
运行结果:
BASE64结果:5rWL6K+V
BASE64解码:测试
二:单向加密:
MessageDigest md=MessageDigest.getInstance("MD5");
md.update("测试".getBytes("utf-8"));
String str3=new BigInteger(1,md.digest()).toString(16);
System.out.println("MD5加密:"+str3);
运行结果:
MD5加密:db06c78d1e24cf708a14ce81c9b617ec