⑴ java 如何採用md5解密
md5隻是消息摘要,不管多長的數據均得到512比特的摘要。
所以md5一般用於驗證,原始消息被修改後,md5的消息摘要會有變化。
md5不是用於加密,也就不能解密,因為有無窮多的數據對應同一個md5消息摘要
⑵ Java MD5如何解密
MD5 不能解密, MD5的破解方式就是 把不同的字元串按MD5加密 然後對比加密後的結果是不是一樣. 在線MD5解密 也是這樣的原理.
⑶ JAVA中有沒有提供MD5演算法的包啊
有,在java.security包的MessageDigest類。
例子:
import java.security.MessageDigest;
public class Test2 {
public static void main(String[] args) {
Test2 t = new Test2();
System.out.println(t.bytesToMD5("a".getBytes()));
}
//把位元組數組轉成16進位制數
public String bytesToHex(byte[] bytes) {
StringBuffer md5str = new StringBuffer();
//把數組每一位元組換成16進制連成md5字元串
int digital;
for (int i = 0; i < bytes.length; i++) {
digital = bytes[i];
if(digital < 0) {
digital += 256;
}
if(digital < 16){
md5str.append("0");
}
md5str.append(Integer.toHexString(digital));
}
return md5str.toString();
}
//把位元組數組轉換成md5
public String bytesToMD5(byte[] input) {
String md5str = null;
try {
//創建一個提供信息摘要演算法的對象,初始化為md5演算法對象
MessageDigest md = MessageDigest.getInstance("MD5");
//計算後獲得位元組數組
byte[] buff = md.digest(input);
//把數組每一位元組換成16進制連成md5字元串
md5str = bytesToHex(buff);
} catch (Exception e) {
e.printStackTrace();
}
return md5str;
}
}
⑷ 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和資料庫裡面的對比。
⑹ MD5演算法如何解密
介紹MD5加密演算法基本情況MD5的全稱是Message-Digest Algorithm 5,在90年代初由MIT的計算機科學實驗室和RSA Data Security Inc發明,經MD2、MD3和MD4發展而來。
Message-Digest泛指位元組串(Message)的Hash變換,就是把一個任意長度的位元組串變換成一定長的大整數。請注意我使用了"位元組串"而不是"字元串"這個詞,是因為這種變換只與位元組的值有關,與字元集或編碼方式無關。
MD5將任意長度的"位元組串"變換成一個128bit的大整數,並且它是一個不可逆的字元串變換演算法,換句話說就是,即使你看到源程序和演算法描述,也無法將一個MD5的值變換回原始的字元串,從數學原理上說,是因為原始的字元串有無窮多個,這有點象不存在反函數的數學函數。
MD5的典型應用是對一段Message(位元組串)產生fingerprint(指紋),以防止被"篡改"。舉個例子,你將一段話寫在一個叫readme.txt文件中,並對這個readme.txt產生一個MD5的值並記錄在案,然後你可以傳播這個文件給別人,別人如果修改了文件中的任何內容,你對這個文件重新計算MD5時就會發現。如果再有一個第三方的認證機構,用MD5還可以防止文件作者的"抵賴",這就是所謂的數字簽名應用。
MD5還廣泛用於加密和解密技術上,在很多操作系統中,用戶的密碼是以MD5值(或類似的其它演算法)的方式保存的,用戶Login的時候,系統是把用戶輸入的密碼計算成MD5值,然後再去和系統中保存的MD5值進行比較,而系統並不"知道"用戶的密碼是什麼。
一些黑客破獲這種密碼的方法是一種被稱為"跑字典"的方法。有兩種方法得到字典,一種是日常搜集的用做密碼的字元串表,另一種是用排列組合方法生成的,先用MD5程序計算出這些字典項的MD5值,然後再用目標的MD5值在這個字典中檢索。
即使假設密碼的最大長度為8,同時密碼只能是字母和數字,共26+26+10=62個字元,排列組合出的字典的項數則是P(62,1)+P(62,2)....+P(62,8),那也已經是一個很天文的數字了,存儲這個字典就需要TB級的磁碟組,而且這種方法還有一個前提,就是能獲得目標賬戶的密碼MD5值的情況下才可以。
在很多電子商務和社區應用中,管理用戶的Account是一種最常用的基本功能,盡管很多Application Server提供了這些基本組件,但很多應用開發者為了管理的更大的靈活性還是喜歡採用關系資料庫來管理用戶,懶惰的做法是用戶的密碼往往使用明文或簡單的變換後直接保存在資料庫中,因此這些用戶的密碼對軟體開發者或系統管理員來說可以說毫無保密可言,本文的目的是介紹MD5的Java Bean的實現,同時給出用MD5來處理用戶的Account密碼的例子,這種方法使得管理員和程序設計者都無法看到用戶的密碼,盡管他們可以初始化它們。但重要的一點是對於用戶密碼設置習慣的保護
⑺ 超大文件如何計算md5
首先,至少沒必要先把整個文件讀到內存里。比如在 php 里,如果有人 md5(file_get_contents(big_file_name)) 就確實非常不妥當。因為 md5 是每 512 bit 作為一個 chunk 進行計算的。所以可以每次讀取一部分的內容(最少 512 bit,比較合適是 st_blksize),進行那些 chunk 部分的計算,之後再讀取下一部分內容繼續計算。簡單先說下,md5是有規范的,提供了現成的演算法(規范的名字就是md5演算法。RFC 1321 The MD5 Message-Digest Algorithm),我們只需要翻譯成c、java、python、js等等代碼。前端算超大文件可以取頭跟尾chunk內容及整個文件的name + update 時間一起算md5值就比較快了,只是為了做唯一標識來做斷點續傳,從業務邏輯上應該夠用了。推薦使用 js spark-md5 開源庫,支持直接append各個部分然後算出md5。我做的斷點續傳功能就是用它在前端算的md5. 各大網盤 TB級別 md5演算法應該是這樣的,樓上幾位都說了文件md5是文件流分塊算出來的,那麼網盤想獲得TB級別文件的md5就必須讀取整個文件的文件流才能得到,但是這么做效率十分低下,運算時間是個問題。但是大家忽略了一個問題,文件在上傳的過程也是分塊上傳的,這些上傳的碎片其實也是文件流。那麼可以把計算md5的時間分攤到每一個碎片上。這樣每上傳一個片段就計算一點等上傳完成了,文件的md5也就算出來了。okTB級別MD5不是問題了。上傳完成md5自然就出來了。 不知道我的猜測大家有其他看法沒有。剛才提出都傳完了就還怎麼秒傳。秒傳最基本的是先要前端算出md5然後傳給後端(可能需要更多種哈希值)我研究了很久前端沒有辦法秒內完成超大文件MD5的,現在用html5 的api 可以算出任意大小文件的 md5 但是耗時相當長。我沒有解決辦法。也沒有想到那些網盤怎麼在前端快速獲取md5的。
⑻ 牛人啊,MD5解密演算法
這種東西沒什麼意義,MD5加密時,一般都會帶幾個其他參數,如:
md.update(password.getBytes()); //原密碼
md.update(「param1」.getBytes()); //參數1
md.update(「param2」.getBytes()); //參數2
這樣出來的密文和未帶參數出來的密文完全不一樣,你再怎麼窮舉也沒用啊。
⑼ 我的密碼用MD5加密演算法加密了,但我想知道到原來的密碼,請高手指點MD5解密演算法用Java實現,謝謝
-_- 貌似MD5沒有解密演算法,本身MD5就是單向函數,無論多長的數據都只能生成128位的MD5值,如果出現破解的話,只能純考字典破解,也就是通過加密字典中的文字,得到的128位數值與你提供的數據進行比對,如果相同的話就認為是解密了... 實際上MD5解密演算法什麼的不存在的說...