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;
 }

你可能感兴趣的:(C++,c,算法,Security,C#)