MD5算法介绍:MD5即Message-Digest Algorithm 5(信息摘要算法5),用于确保信息传输完整一致。MD5的主要作用是将数据量巨大的信息用数字签名软件签署私人密钥前被"压缩"成一种保密的格式,也就是说把一个任意长度的字节串变换成一定长的十六进制数字串。
MD5算法详解:MD5以512位分组来处理输入的信息,且每一分组又被划分为16个32位子分组,经过了一系列的处理后,算法的输出由四个32位分组组成,将这四个32位分组级联后将生成一个128位散列值。
使用Java通过的API实现MD5加密程序如下:
<span style="font-size:18px;">import java.security.MessageDigest;
public class MD5 {
public static final String KEY_MD5 = "MD5";
public static char hexDigits[]={'0','1','2','3','4','5','6','7','8','9',
'A','B','C','D','E','F','G',
'H','I','J','K','L','M','N',
'O','P','Q','R','S','T',
'U','V','W','X','Y','Z'};
//MD5加密
public static byte[] encryptMD5(byte[] data) throws Exception {
MessageDigest md5 = MessageDigest.getInstance(KEY_MD5);
md5.update(data);
return md5.digest();
}
public static void main(String[] args) throws Exception {
String inputStr="这是一个测试字符串aaabbbccc111222333";
System.out.println("原始数据:"+inputStr);
byte[] inputData = inputStr.getBytes();
byte[] outDate = encryptMD5(inputData);
System.out.println("原始加密数据:"+outDate);
//把密文转换成16进制字符串的形式
int j = outDate.length;
char str[] = new char[j * 2];
int k = 0;
for (int i = 0; i < j; i++) {
byte byte0 = outDate[i];
str[k++] = hexDigits[byte0 >>> 4 & 0xf];
str[k++] = hexDigits[byte0 & 0xf];
}
System.out.print("16进制字符串形式密文:");
System.out.println(str);
}
}
import java.security.MessageDigest;
public class MD5 {
public static final String KEY_MD5 = "MD5";
public static char hexDigits[]={'0','1','2','3','4','5','6','7','8','9',
'A','B','C','D','E','F','G',
'H','I','J','K','L','M','N',
'O','P','Q','R','S','T',
'U','V','W','X','Y','Z'};
//MD5加密
public static byte[] encryptMD5(byte[] data) throws Exception {
MessageDigest md5 = MessageDigest.getInstance(KEY_MD5);
md5.update(data);
return md5.digest();
}
public static void main(String[] args) throws Exception {
String inputStr="这是一个测试字符串aaabbbccc111222333";
System.out.println("原始数据:"+inputStr);
byte[] inputData = inputStr.getBytes();
byte[] outDate = encryptMD5(inputData);
System.out.println("原始加密数据:"+outDate);
//把密文转换成16进制字符串的形式
int j = outDate.length;
char str[] = new char[j * 2];
int k = 0;
for (int i = 0; i < j; i++) {
byte byte0 = outDate[i];
str[k++] = hexDigits[byte0 >>> 4 & 0xf];
str[k++] = hexDigits[byte0 & 0xf];
}
System.out.print("16进制字符串形式密文:");
System.out.println(str);
}
}
</span>输出结果为:
<span style="font-size:18px;">原始数据:这是一个测试字符串aaabbbccc111222333
原始加密数据:[B@17e121c
16进制字符串形式密文:ECE58955645D34EBC31EC9FD9DE69581</span>
本文介绍了MD5算法,一种用于确保信息传输完整一致的摘要算法。MD5将大量信息压缩为128位散列值。文章还详细讲解了MD5的处理流程,并提供了Java API实现MD5加密的示例。
253

被折叠的 条评论
为什么被折叠?



