Java MD5如何解密?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java MD5如何解密?相关的知识,希望对你有一定的参考价值。

a经过MD5加密DigestUtils.md5Hex(a)后为0cc175b9c0f1b6a831c399e269772661
用什么方法将0cc175b9c0f1b6a831c399e269772661解密还原成a?
DigestUtils类有没有啥方法可以完成?
谢谢!!!
用在线MD5解密或者什么数据字典的话就不用了!

MD5是单向加密的,不管何种数据进行MD5加密都会得到固定长度的字符串,
MD5一般用户文件完整性的校验,也有用来做密码加密的。
想要破解MD5,因其本身的算法不可逆,故只能使用穷举法,也就是不断拼字符串加密和已知的MD5字符串进行比对,这是一个相当大的工程,需要庞大的数据基础。
参考技术A 有方法,不过是保密的,没有公开,因为大部分加密是采用MD5,公开解密算法,好多都不安全了 参考技术B md5只是消息摘要,不管多长的数据均得到512比特的摘要。
所以md5一般用于验证,原始消息被修改后,md5的消息摘要会有变化。
md5不是用于加密,也就不能解密,因为有无穷多的数据对应同一个md5消息摘要
参考技术C MD5 不能解密, MD5的破解方式就是 把不同的字符串按MD5加密 然后对比加密后的结果是不是一样. 在线MD5解密 也是这样的原理.

Java的MD5加密和解密

简单demo:

Java代码  技术分享
  1. import  java.security.*;  
  2. import  java.security.spec.*;  
  3.   
  4. class  MD5_test {  
  5.  public   final   static  String MD5(String s) {  
  6.   char  hexDigits[] = {  ‘0‘ ,  ‘1‘ ,  ‘2‘ ,  ‘3‘ ,  ‘4‘ ,  ‘5‘ ,  ‘6‘ ,  ‘7‘ ,  ‘8‘ ,  ‘9‘ ,  
  7.     ‘a‘ ,  ‘b‘ ,  ‘c‘ ,  ‘d‘ ,  ‘e‘ ,  ‘f‘  };  
  8.   try  {  
  9.    byte [] strTemp = s.getBytes();  
  10.    MessageDigest mdTemp = MessageDigest.getInstance("MD5" );  
  11.    mdTemp.update(strTemp);  
  12.    byte [] md = mdTemp.digest();  
  13.    int  j = md.length;  
  14.    char  str[] =  new   char [j *  2 ];  
  15.    int  k =  0 ;  
  16.    for  ( int  i =  0 ; i < j; i++) {  
  17.     byte  byte0 = md[i];  
  18.     str[k++] = hexDigits[byte0 >>> 4  &  0xf ];  
  19.     str[k++] = hexDigits[byte0 & 0xf ];  
  20.    }  
  21.    return   new  String(str);  
  22.   } catch  (Exception e) {  
  23.    return   null ;  
  24.   }  
  25.  }  
  26.   
  27.  public   static   void  main(String[] args) {  
  28.   // MD5_Test aa = new MD5_Test();   
  29.   System.out.print(MD5_test.MD5("b" ));  
  30.  }  
  31. }  
  1. import java.security.*;  
  2. import java.security.spec.*;  
  3.   
  4. class MD5_test {  
  5.  public final static String MD5(String s) {  
  6.   char hexDigits[] = { ‘0‘, ‘1‘, ‘2‘, ‘3‘, ‘4‘, ‘5‘, ‘6‘, ‘7‘, ‘8‘, ‘9‘,  
  7.     ‘a‘, ‘b‘, ‘c‘, ‘d‘, ‘e‘, ‘f‘ };  
  8.   try {  
  9.    byte[] strTemp = s.getBytes();  
  10.    MessageDigest mdTemp = MessageDigest.getInstance("MD5");  
  11.    mdTemp.update(strTemp);  
  12.    byte[] md = mdTemp.digest();  
  13.    int j = md.length;  
  14.    char str[] = new char[j * 2];  
  15.    int k = 0;  
  16.    for (int i = 0; i < j; i++) {  
  17.     byte byte0 = md[i];  
  18.     str[k++] = hexDigits[byte0 >>> 4 & 0xf];  
  19.     str[k++] = hexDigits[byte0 & 0xf];  
  20.    }  
  21.    return new String(str);  
  22.   } catch (Exception e) {  
  23.    return null;  
  24.   }  
  25.  }  
  26.   
  27.  public static void main(String[] args) {  
  28.   // MD5_Test aa = new MD5_Test();  
  29.   System.out.print(MD5_test.MD5("b"));  
  30.  }  
  31. }  

 

Java代码  技术分享
  1. import  java.security.MessageDigest;  
  2.   
  3.   
  4. public   class  MD5andKL {  
  5.  // MD5加码。32位   
  6.  public   static  String MD5(String inStr) {  
  7.   MessageDigest md5 = null ;  
  8.   try  {  
  9.    md5 = MessageDigest.getInstance("MD5" );  
  10.   } catch  (Exception e) {  
  11.    System.out.println(e.toString());  
  12.    e.printStackTrace();  
  13.    return   "" ;  
  14.   }  
  15.   char [] charArray = inStr.toCharArray();  
  16.   byte [] byteArray =  new   byte [charArray.length];  
  17.   
  18.   for  ( int  i =  0 ; i < charArray.length; i++)  
  19.    byteArray[i] = (byte ) charArray[i];  
  20.   
  21.   byte [] md5Bytes = md5.digest(byteArray);  
  22.   
  23.   StringBuffer hexValue = new  StringBuffer();  
  24.   
  25.   for  ( int  i =  0 ; i < md5Bytes.length; i++) {  
  26.    int  val = (( int ) md5Bytes[i]) &  0xff ;  
  27.    if  (val <  16 )  
  28.     hexValue.append("0" );  
  29.    hexValue.append(Integer.toHexString(val));  
  30.   }  
  31.   
  32.   return  hexValue.toString();  
  33.  }  
  34.   
  35.  // 可逆的加密算法   
  36.  public   static  String KL(String inStr) {  
  37.   // String s = new String(inStr);   
  38.   char [] a = inStr.toCharArray();  
  39.   for  ( int  i =  0 ; i < a.length; i++) {  
  40.    a[i] = (char ) (a[i] ^  ‘t‘ );  
  41.   }  
  42.   String s = new  String(a);  
  43.   return  s;  
  44.  }  
  45.   
  46.  // 加密后解密   
  47.  public   static  String JM(String inStr) {  
  48.   char [] a = inStr.toCharArray();  
  49.   for  ( int  i =  0 ; i < a.length; i++) {  
  50.    a[i] = (char ) (a[i] ^  ‘t‘ );  
  51.   }  
  52.   String k = new  String(a);  
  53.   return  k;  
  54.  }  
  55.    
  56.  // 测试主函数   
  57.  public   static   void  main(String args[]) {  
  58.   String s = new  String( "a" );  
  59.   System.out.println("原始:"  + s);  
  60.   System.out.println("MD5后:"  + MD5(s));  
  61.   System.out.println("MD5后再加密:"  + KL(MD5(s)));  
  62.   System.out.println("解密为MD5后的:"  + JM(KL(MD5(s))));  
  63.  }  
  64. }  
  1. import java.security.MessageDigest;  
  2.   
  3.   
  4. public class MD5andKL {  
  5.  // MD5加码。32位  
  6.  public static String MD5(String inStr) {  
  7.   MessageDigest md5 = null;  
  8.   try {  
  9.    md5 = MessageDigest.getInstance("MD5");  
  10.   } catch (Exception e) {  
  11.    System.out.println(e.toString());  
  12.    e.printStackTrace();  
  13.    return "";  
  14.   }  
  15.   char[] charArray = inStr.toCharArray();  
  16.   byte[] byteArray = new byte[charArray.length];  
  17.   
  18.   for (int i = 0; i < charArray.length; i++)  
  19.    byteArray[i] = (byte) charArray[i];  
  20.   
  21.   byte[] md5Bytes = md5.digest(byteArray);  
  22.   
  23.   StringBuffer hexValue = new StringBuffer();  
  24.   
  25.   for (int i = 0; i < md5Bytes.length; i++) {  
  26.    int val = ((int) md5Bytes[i]) & 0xff;  
  27.    if (val < 16)  
  28.     hexValue.append("0");  
  29.    hexValue.append(Integer.toHexString(val));  
  30.   }  
  31.   
  32.   return hexValue.toString();  
  33.  }  
  34.   
  35.  // 可逆的加密算法  
  36.  public static String KL(String inStr) {  
  37.   // String s = new String(inStr);  
  38.   char[] a = inStr.toCharArray();  
  39.   for (int i = 0; i < a.length; i++) {  
  40.    a[i] = (char) (a[i] ^ ‘t‘);  
  41.   }  
  42.   String s = new String(a);  
  43.   return s;  
  44.  }  
  45.   
  46.  // 加密后解密  
  47.  public static String JM(String inStr) {  
  48.   char[] a = inStr.toCharArray();  
  49.   for (int i = 0; i < a.length; i++) {  
  50.    a[i] = (char) (a[i] ^ ‘t‘);  
  51.   }  
  52.   String k = new String(a);  
  53.   return k;  
  54.  }  
  55.    
  56.  // 测试主函数  
  57.  public static void main(String args[]) {  
  58.   String s = new String("a");  
  59.   System.out.println("原始:" + s);  
  60.   System.out.println("MD5后:" + MD5(s));  
  61.   System.out.println("MD5后再加密:" + KL(MD5(s)));  
  62.   System.out.println("解密为MD5后的:" + JM(KL(MD5(s))));  
  63.  }  
  64. }  

 

以上是关于Java MD5如何解密?的主要内容,如果未能解决你的问题,请参考以下文章

如何在java中实现md5加密和解密

jmeter如何使用使用MD5加密?

MD5加密文件如何解密?

MD5算法如何解密

MD5+DES在C#.NET与Java/Android中的加解密使用

Java加密,解密中的bc,cc是什么意思