首先
???我看到很多貼子,上面描述MD5加密解密等話題,因此寫此文章為了把MD5加密問題簡單的說個透徹,并且給大家已經實踐過的代碼。
其次???MD5加密并不是把原文加密,這個大家得注意,既然沒有把原文加密何來的解密呢?簡直是個笑話。MD5的用途就是把一段原文數據通過一定的算法生成16字節的密文,通過這個密文我們可以檢查原文的數據是否被修改過。常用在網絡中明文數據傳輸,防止傳輸過程中內容被惡意修改。典型的應用協議為radius,radius協議中有16byte就是MD5所留的,把用戶的密碼加在報文尾部進行MD5,把結果存在網絡中,所以明文部分看不到用戶的密碼,當服務器收到此包,用同樣的方法進行MD5,如果加密出來的16byte一樣,說明是有效的未被惡意修改的網絡包。
最后附上實現的代碼
- 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 閱讀(287)
評論(0) 編輯 收藏 所屬分類:
基礎編程篇