javamd5加密解密類
⑴ java MD5如何解密
MD5 不能解密, MD5的破解方式就是 把不同的字元串按MD5加密 然後對比加密後的結果是不是一樣. 在線MD5解密 也是這樣的原理.
⑵ java中DES、MD5加密演算法在哪個包中如何分別調用這兩個方法實現對輸入數據的加密、解密
java.security.MessageDigest
/*
*MD5演算法
*/
publicclassMD5{
//全局數組
privatefinalstaticString[]strDigits={"0","1","2","3","4","5",
"6","7","8","9","a","b","c","d","e","f"};
publicMD5(){
}
//返回形式為數字跟字元串
(bytebByte){
intiRet=bByte;
//System.out.println("iRet="+iRet);
if(iRet<0){
iRet+=256;
}
intiD1=iRet/16;
intiD2=iRet%16;
returnstrDigits[iD1]+strDigits[iD2];
}
//返回形式只為數字
privatestaticStringbyteToNum(bytebByte){
intiRet=bByte;
System.out.println("iRet1="+iRet);
if(iRet<0){
iRet+=256;
}
returnString.valueOf(iRet);
}
//轉換位元組數組為16進制字串
(byte[]bByte){
StringBuffersBuffer=newStringBuffer();
for(inti=0;i<bByte.length;i++){
sBuffer.append(byteToArrayString(bByte[i]));
}
returnsBuffer.toString();
}
publicstaticStringGetMD5Code(StringstrObj){
StringresultString=null;
try{
resultString=newString(strObj);
MessageDigestmd=MessageDigest.getInstance("MD5");
//md.digest()該函數返回值為存放哈希值結果的byte數組
resultString=byteToString(md.digest(strObj.getBytes()));
}catch(NoSuchAlgorithmExceptionex){
ex.printStackTrace();
}
returnresultString;
}
publicstaticvoidmain(String[]args){
MD5getMD5=newMD5();
System.out.println(getMD5.GetMD5Code("000000"));
}
}
⑶ 求Java的MD5加密解密實現類。 要實現對用戶的密碼進行加密! 然後驗證用戶的密碼!
我簡單說下吧,加密就是存進資料庫的時候變成MD5存進去,解密,就是對比的時候,將用戶輸入的密碼轉換成MD5和資料庫裡面的對比。
⑷ 如何在java中實現md5加密和解密
package endecrypt;
02.
03.import java.io.UnsupportedEncodingException;
04.import java.security.MessageDigest;
05.import java.security.NoSuchAlgorithmException;
06.
07./**
08. * 採用MD5加密解密
09. * @author tfq
10. * @datetime 2011-10-13
11. */
12.public class MD5Util {
13.
14. /***
15. * MD5加碼 生成32位md5碼
16. */
17. public static String string2MD5(String inStr){
18. MessageDigest md5 = null;
19. try{
20. md5 = MessageDigest.getInstance("MD5");
21. }catch (Exception e){
22. System.out.println(e.toString());
23. e.printStackTrace();
24. return "";
25. }
26. char[] charArray = inStr.toCharArray();
27. byte[] byteArray = new byte[charArray.length];
28.
29. for (int i = 0; i < charArray.length; i++)
30. byteArray[i] = (byte) charArray[i];
31. byte[] md5Bytes = md5.digest(byteArray);
32. StringBuffer hexValue = new StringBuffer();
33. for (int i = 0; i < md5Bytes.length; i++){
34. int val = ((int) md5Bytes[i]) & 0xff;
35. if (val < 16)
36. hexValue.append("0");
37. hexValue.append(Integer.toHexString(val));
38. }
39. return hexValue.toString();
40.
41. }
42.
43. /**
44. * 加密解密演算法 執行一次加密,兩次解密
45. */
46. public static String convertMD5(String inStr){
47.
48. char[] a = inStr.toCharArray();
49. for (int i = 0; i < a.length; i++){
50. a[i] = (char) (a[i] ^ 't');
51. }
52. String s = new String(a);
53. return s;
54.
55. }
⑸ java md5加密後怎麼解密
MD5理論上不可解密,只有某些暴力破解的方式,詳情網路查詢MD5在線解密,可以找到一些網站。ps:該回答不負法律責任,請慎重使用
⑹ java中,從資料庫取出來的密碼加密了,用代碼怎麼實現md5解密
md5是不可逆的,只不過用的人多了,就有人創建了一個md5密碼表,應該就是傳說中的彩虹表,蜜要是有這個表就可以了
⑺ java 如何採用md5解密
md5隻是消息摘要,不管多長的數據均得到512比特的摘要。
所以md5一般用於驗證,原始消息被修改後,md5的消息摘要會有變化。
md5不是用於加密,也就不能解密,因為有無窮多的數據對應同一個md5消息摘要
⑻ 用Java做了一個項目。找了一個Java的MD5加密的類。不知道具體該怎麼用。請大神幫忙給詳細說說。
比如 b = md5(a)
a 是原文, md5運算以後得到b, 以現有的計算機水平,很難根據b反推出a
所以人們用它來做驗證工作,舉個簡單初級的例子:
讀取機器的硬體信息再加上特定的字元串,經過md5運算得到一個授權碼,保存在目標機器上,用以檢測是否盜版軟體。
還有現在不少的開放平台,為每個App指定所謂的secretkey, App在向平台提交信息時,就是帶著 md5(用戶id等唯一信息 + secretkey) 的結果,用以證明請求的合法性。