消息摘要算法的主要特征是加密过程不需要密钥,并且经过加密的数据无法被解密,只有输入相同的明文数据经过相同的消息摘要算法才能得到相同的密文。消息摘要算法不存在密钥的管理与分发问题,适合于分布式网络相同上使用。由于其加密计算的工作量相当可观,所以以前的这种算法通常只用于数据量有限的情况下的加密,例如计算机的口令就是用不可逆加密算法加密的。
**
* 消息摘要算法之MD
* @description:
* MD(Message Digest)
* MD家族包括MD2,MD4及MD5,都是采用128位摘要信息算法
* @date 2015-10-30 下午4:09:44
*/
public class MsgDigestMd {
private static String mdStr = "message digest md";
public static void main(String[] args) {
jdkMd5();
jdkMd2();
}
private static void jdkMd5() {
MessageDigest md;
try {
md = MessageDigest.getInstance("MD5");
byte[] md5Bytes=md.digest(mdStr.getBytes());
System.out.println("通过jdk对数据MD5摘要算法结果为:"+Base64.encode(md5Bytes));
}
catch (NoSuchAlgorithmException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
private static void jdkMd2() {
MessageDigest md;
try {
md = MessageDigest.getInstance("MD2");
byte[] md2Bytes=md.digest(mdStr.getBytes());
System.out.println("通过jdk对数据MD2摘要算法结果为:"+Base64.encode(md2Bytes));
}
catch (NoSuchAlgorithmException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}