在写代码的时候经常用到加密的方法,加密算法一般分为以下几种


注:本文不做加密算法具体介绍,如果有兴趣可以搜索算法的详细介绍。

一、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