Android網絡傳輸中的加密算法:MD5加密方法

MD5是網絡傳輸中最常用的算法,瞭解這個算法原理後就能大致知道加密是怎麼一回事了。

MD5是不可逆的,只能加密而不能解密。比如明文是yanzi1225627,得到MD5加密後的字符串是:14F2AE15259E2C276A095E7394DA0CA9  但不能由後面一大串倒推出yanzi1225627.因此可以用來存儲用戶輸入的密碼在服務器上。現在下載文件校驗文件是否中途被篡改也是用的它,原理參見:http://blog.csdn.net/forgotaboutgirl/article/details/7258109 無論在Android上還是pc上用java實現MD5都比較容易,因爲java已經把它做到了java.security.MessageDigest裏。下面是一個MD5Util.java類:

  1. package org.md5.util;  
  2.   
  3. import java.security.MessageDigest;  
  4. public class MD5Util {  
  5.     public final static String getMD5String(String s) {  
  6.         char hexDigits[] = { '0''1''2''3''4',  
  7.                 '5''6''7''8''9',  
  8.                 'A''B''C''D''E''F' };  
  9.         try {  
  10.             byte[] btInput = s.getBytes();  
  11.             //獲得MD5摘要算法的 MessageDigest 對象  
  12.             MessageDigest mdInst = MessageDigest.getInstance("MD5");  
  13.             //使用指定的字節更新摘要  
  14.             mdInst.update(btInput);  
  15.             //獲得密文  
  16.             byte[] md = mdInst.digest();  
  17.             //把密文轉換成十六進制的字符串形式  
  18.             int j = md.length;  
  19.             char str[] = new char[j * 2];  
  20.             int k = 0;  
  21.             for (int i = 0; i < j; i++) {  
  22.                 byte byte0 = md[i];  
  23.                 str[k++] = hexDigits[byte0 >>> 4 & 0xf];  
  24.                 str[k++] = hexDigits[byte0 & 0xf];  
  25.             }  
  26.             return new String(str);  
  27.         }  
  28.         catch (Exception e) {  
  29.             e.printStackTrace();  
  30.             return null;  
  31.         }  
  32.     }  
  33. }
通過下面兩行代碼調用:

/************************************MD5加密測試*****************************/
String srcString = "yanzi1225627";
System.out.println("MD5加密後 = " + MD5Util.getMD5String(srcString));


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章