MD5 16位 加密字符串标准算法
首先先了解md5加密算法的原理,太高深太专业的说法,我不会,就算会说了也可能大家不明白
?
原理:将存储字符串的bit(1byte = 8bit)顺序打乱,然后重组,抽取32位byte,每2个再进行组合,形成16组byte[]数组,然后在依次转化为16进制。? 这就是16位的MD5加密算法,具体算法如下:
?
public static String getMD5(byte[] source) {
??String s = null;
??char hexDigits[] = { // 用来将字节转换成 16 进制表示的字符
??'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd',
????'e', 'f' };
??try {
???java.security.MessageDigest md = java.security.MessageDigest
?????.getInstance("MD5");
???md.update(source);
???byte tmp[] = md.digest(); // MD5 的计算结果是一个 128 位的长整数,
???// 用字节表示就是 16 个字节
???char str[] = new char[16 * 2]; // 每个字节用 16 进制表示的话,使用两个字符,
???// 所以表示成 16 进制需要 32 个字符
???int k = 0; // 表示转换结果中对应的字符位置
???for (int i = 0; i < 16; i++) { // 从第一个字节开始,对 MD5 的每一个字节
????// 转换成 16 进制字符的转换
????byte byte0 = tmp[i]; // 取第 i 个字节
????str[k++] = hexDigits[byte0 >>> 4 & 0xf]; // 取字节中高 4 位的数字转换,
????// >>> 为逻辑右移,将符号位一起右移
????str[k++] = hexDigits[byte0 & 0xf]; // 取字节中低 4 位的数字转换
???}
???s = new String(str); // 换后的结果转换为字符串
??} catch (Exception e) {
???e.printStackTrace();
??}
??return s;
?}
?
?
有时候我们需要用到byte[16]....byte[0] =?'0 x b[0]+b[1]'? --这不是代码是一个形象的比如
修改如下:
public static byte[] getMD5Byte(byte[] source) {
??byte[] b = new byte[16];
??char hexDigits[] = {?
??'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd',
????'e', 'f' };
??
??try {
???java.security.MessageDigest md = java.security.MessageDigest
?????.getInstance("MD5");
???md.update(source);
???byte tmp[] = md.digest();?
???char str[] = new char[16 * 2];?
???int k = 0;?
???for (int i = 0; i < 16; i++) {????
????byte byte0 = tmp[i];
????str[k++] = hexDigits[byte0 >>> 4 & 0xf];?
????str[k++] = hexDigits[byte0 & 0xf];?
????int a = Integer.parseInt((str[k-2]+""+str[k-1]).toString(),16);
????b[i] = (byte)a;
???}
??} catch (Exception e) {
???e.printStackTrace();
??}
??return b;
?}