首先
???我看到很多貼子,上面描述MD5加密解密等話題,因此寫此文章為了把MD5加密問題簡單的說個透徹,并且給大家已經(jīng)實(shí)踐過的代碼。
其次???MD5加密并不是把原文加密,這個大家得注意,既然沒有把原文加密何來的解密呢?簡直是個笑話。MD5的用途就是把一段原文數(shù)據(jù)通過一定的算法生成16字節(jié)的密文,通過這個密文我們可以檢查原文的數(shù)據(jù)是否被修改過。常用在網(wǎng)絡(luò)中明文數(shù)據(jù)傳輸,防止傳輸過程中內(nèi)容被惡意修改。典型的應(yīng)用協(xié)議為radius,radius協(xié)議中有16byte就是MD5所留的,把用戶的密碼加在報文尾部進(jìn)行MD5,把結(jié)果存在網(wǎng)絡(luò)中,所以明文部分看不到用戶的密碼,當(dāng)服務(wù)器收到此包,用同樣的方法進(jìn)行MD5,如果加密出來的16byte一樣,說明是有效的未被惡意修改的網(wǎng)絡(luò)包。
最后附上實(shí)現(xiàn)的代碼
- import?java.security.*;
- public?class?MD5?{
- ??/**
- ???*?MD5
- ???*
- ???*?@author?Dreamer
- ???*/
- ??public?MD5()?{
- ??}
- ??public?static?byte[]?md5(byte[]?in)?{
- ????MessageDigest?md?=?null;
- ????byte[]?out?=?new?byte[16];
- ????try?{
- ??????md?=?MessageDigest.getInstance("MD5");
- ????}
- ????catch?(NoSuchAlgorithmException?ex)?{
- ??????System.out.println(ex.toString());
- ????}
- ????md.reset();
- ????md.update(in);
- ????out?=?md.digest();
- ????return?out;
- ??}
- ??public?static?byte[]?md5(byte[]?in,?int?len)?{
- ????MessageDigest?md?=?null;
- ????byte[]?out?=?new?byte[16];
- ????try?{
- ??????md?=?MessageDigest.getInstance("MD5");
- ????}
- ????catch?(NoSuchAlgorithmException?ex)?{
- ??????System.out.println(ex.toString());
- ????}
- ????md.reset();
- ????md.update(in,?0,?len);
- ????out?=?md.digest();
- ????return?out;
- ??}
- }
posted on 2006-08-10 09:51
matthew 閱讀(285)
評論(0) 編輯 收藏 所屬分類:
基礎(chǔ)編程篇