信息完整性可通过提取并对比消息摘要的方式来实现。消息摘要就是根据一定的运算规则对原始数据进行某种形式的信息提取,通过消息摘要后的消息摘要的长度总是固定的,它也叫做数据指纹,因为它可以唯一的标识一段数据。常见的摘要算法有:sha1、sha256、md5、crc32等。
下面例子演示了SHA256摘要算法:
public class SHA256 {
/**
* 实现SHA256加密
* @param str 加密后的报文
* @return
*/
public static String getSHA256(String str) {
MessageDigest messageDigest;
String encodestr = "";
try {
messageDigest = MessageDigest.getInstance("SHA-256");
messageDigest.update(str.getBytes("UTF-8"));
encodestr = byte2Hex(messageDigest.digest());
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
return encodestr;
}
private static String byte2Hex(byte[] bytes) {
StringBuffer stringBuffer = new StringBuffer();
String temp = null;
for (int i = 0; i < bytes.length; i++) {
temp = Integer.toHexString(bytes[i] & 0xFF);
if (temp.length() == 1) {
stringBuffer.append("0");
}
stringBuffer.append(temp);
}
return stringBuffer.toString();
}
}
/**
* 测试SHA256摘要算法
*/
@Test
public void test2() throws Exception {
String content = "你好世界";
System.out.println(content + ": 第一次摘要后的字符串为:" + SHA256.getSHA256(content));
System.out.println(content + ": 第二次摘要后的字符串为:" + SHA256.getSHA256(content));
}
从上面的内容我们可以了解到摘要算法的特性,发送方和接收方可以约定使用相同的摘要算法对原文进行摘要运算,双方得出的消息摘要若一致,说明数据在传输过程中没有被篡改。