摘要算法不是加密算法。
这里实现的比较简单,对结果都做了16进制的转换。
直接上代码。
package Digest;
import java.security.MessageDigest;
/**
* @创建人
* @创建时间
* @描述 数字摘要算法代码实现,常见的有:MD5,SHA-1,SHA-256,SHA-512
*/
public class Digest {
/**
*
* @param aByte 原文
* @param algorithm 算法类型
* @return MD5:128位长度,SHA-1:160位,SHA-256:256位,SHA-512:
* @throws Exception
*/
public static String getDigest(byte[] aByte,String algorithm) throws Exception{
//获取一个摘要算法的对象MessageDigest,并传入参数:算法类型
//此处需要抛出异常
MessageDigest messageDigest = MessageDigest.getInstance(algorithm);
//执行算法操作,获得摘要,此算法执行后得到的是byte字节数组(即密文)
byte[] digest = messageDigest.digest(aByte);
StringBuilder stringBuilder = new StringBuilder();
//对密文进行迭代,将其转换为16进制
for (byte b : digest) {
String toHexString = Integer.toHexString(b & 0xff);//转换为16进制只需要逐位相与即可
//对转译密文中1位的部分(),高位补0
if (toHexString.length() == 1){
toHexString = "0" + toHexString;
}
stringBuilder.append(toHexString);
}
return String.valueOf(stringBuilder);
}
public static void main(String[] args) throws Exception {
String input = "哪一个男孩不想要一辆劳斯莱斯呢?————硬核的半佛仙人";
String MD5Digest = getDigest(input.getBytes(),"MD5");
System.out.println("MD5哈希之后的消息是:"+MD5Digest);
String SHA1Digest = getDigest(input.getBytes(),"SHA-1");
System.out.println("MD5哈希之后的消息是:"+SHA1Digest);
String MSHA256Digest = getDigest(input.getBytes(),"SHA-256");
System.out.println("MD5哈希之后的消息是:"+MSHA256Digest);
String SHA512Digest = getDigest(input.getBytes(),"SHA-512");
System.out.println("MD5哈希之后的消息是:"+SHA512Digest);
}
}
测试