1 散列函数(也叫作hash函数)
1.1 消息摘要
- 消息摘要(Message Digest)又称数字摘要(Digital Digest)。
- 他是一个唯一对应一个消息或者文本的固定长度的值,它是一个单向的hash加密函数对消息进行作用而产生的。
- 使用数字摘要生成的值是不可以篡改的,为了保证文件或者值的安全。
1.2 特点
- 无论消息有多长,计算出来的消息摘要的长度总是固定的。例如用MD5算法摘要的消息有128个比特位,用SHA-1算法摘要的消息有160比特位的输出。
- 只要输入的消息不同,对其进行摘要后产生的摘要消息也必定不相同,但是相同的输入必会产生相同的输出。
- 消息摘要是单向的不可逆的。
1.3 常见算法
MD5、SHA-1、SHA-256、SHA-512
1.4 代码实现
package com.lh.basecryptology.digest;
import com.sun.org.apache.xerces.internal.impl.dv.util.Base64;
import java.security.MessageDigest;
public class DigestDemo {
public static void main(String[] args) throws Exception {
// 原文
String text ="Aa";
// 算法
String algorithm = "MD5";
String base64 = encryptMD5Base64(text, algorithm);
System.out.println("Base64: " + base64);
String md5 = encrypt(text, algorithm);
System.out.println("MD5: " + md5);
algorithm = "SHA-1";
String sha1 = encrypt(text, algorithm);
System.out.println("SHA-1: " + sha1);
algorithm = "SHA-256";
String sha256 = encrypt(text, algorithm);
System.out.println("SHA-256: " + sha256);
algorithm = "SHA-512";
String sha512 = encrypt(text, algorithm);
System.out.println("SHA-512: " + sha512);
}
/**
*
* @param text 原文
* @param algorithm 算法
* @return 密文
* @throws Exception
*/
private static String encryptMD5Base64(String text, String algorithm) throws Exception {
// 获取数字摘要对象
MessageDigest messageDigest = MessageDigest.getInstance(algorithm);
// 加密
byte[] digest = messageDigest.digest(text.getBytes());
// base64转码
return Base64.encode(digest);
}
/**
* 加密转16进制
* @param text 原文
* @param algorithm 算法
* @return 密文
* @throws Exception 异常
*/
private static String encrypt(String text, String algorithm) throws Exception {
// 获取数字摘要对象
MessageDigest messageDigest = MessageDigest.getInstance(algorithm);
// 加密
byte[] digest = messageDigest.digest(text.getBytes());
// 对密文进行迭代转换成16进制
StringBuilder sb = bytes2HexString(digest);
return sb.toString();
}
/**
* 字节数组转16进制字符
* @param digest 数组
* @return 结果
*/
private static StringBuilder bytes2HexString(byte[] digest) {
StringBuilder sb = new StringBuilder();
for (byte b : digest) {
String s = Integer.toHexString(b & 0xff);
if(s.length()==1){
s = "0"+s;
}
sb.append(s);
}
return sb;
}
}