MD5加密

来源:互联网 发布:香港迪斯尼万圣节知乎 编辑:程序博客网 时间:2024/05/15 02:06

Message Digest Algorithm MD5(中文名为消息摘要算法第五版)为计算机安全领域广泛使用的一种散列函数,用以提供消息的完整性保护。MD5用的是哈希函数,在计算机网络中应用较多的不可逆加密算法有RSA公司发明的MD5算法和由美国国家技术标准研究所建议的安全散列算法SHA。

MD5 - 2711082222 - 蓉蓉来啦的博客

/**
* MD5 32位加密方法一 小写
* @param str
* @return
*/

public final static String get32MD5(String s) {
char hexDigits[] = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f' };
try {
byte[] strTemp = s.getBytes();
//使用MD5创建MessageDigest对象
MessageDigest mdTemp = MessageDigest.getInstance("MD5");
mdTemp.update(strTemp);
byte[] md = mdTemp.digest();
int j = md.length;
char str[] = new char[j * 2];
int k = 0;
for (int i = 0; i < j; i++) {
byte b = md[i];
//System.out.println((int)b);
//将没个数(int)b进行双字节加密
str[k++] = hexDigits[b >> 4 & 0xf];
str[k++] = hexDigits[b & 0xf];
}
return new String(str);
} catch (Exception e) {
return null;
}

/**
* MD5 32位加密方法二 小写
* @param str
* @return
*/

public final static String get32MD5Str(String str) { 
MessageDigest messageDigest = null; 
try { 
messageDigest = MessageDigest.getInstance("MD5"); 
messageDigest.reset(); 
messageDigest.update(str.getBytes("UTF-8")); 
} catch (NoSuchAlgorithmException e) { 
System.out.println("NoSuchAlgorithmException caught!"); 
System.exit(-1); 
} catch (UnsupportedEncodingException e) { 
e.printStackTrace(); 

byte[] byteArray = messageDigest.digest(); 
StringBuffer md5StrBuff = new StringBuffer(); 
for (int i = 0; i < byteArray.length; i++) { 
if (Integer.toHexString(0xFF & byteArray[i]).length() == 1) 
md5StrBuff.append("0").append(Integer.toHexString(0xFF & byteArray[i])); 
else 
md5StrBuff.append(Integer.toHexString(0xFF & byteArray[i])); 

return md5StrBuff.toString(); 
}


 

/**
* Md5 32位 or 16位 加密
* @param plainText 
* @return 32位加密
*/
public static String Md5(String plainText ) {
StringBuffer buf = null;
try {
MessageDigest md = MessageDigest.getInstance("MD5"); 
md.update(plainText.getBytes());
byte b[] = md.digest(); 
int i; 
buf = new StringBuffer(""); 
for (int offset = 0; offset < b.length; offset++) {
i = b[offset];
if(i<0) i+= 256;
if(i<16)
buf.append("0");
buf.append(Integer.toHexString(i));
}
// Log.e("555","result: " + buf.toString());//32位的加密 
//Log.e("555","result: " + buf.toString().substring(8,24));//16位的加密

} catch (NoSuchAlgorithmException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return buf.toString(); 
}


 

附:java String 转化成 MD5 byte[]
public static byte[] hexStringToByte(String hex) {
int len = (hex.length() / 2); 
byte[] result = new byte[len];
char[] achar = hex.toCharArray(); 
for (int i = 0; i < len; i++) {
int pos = i * 2; 
result[i] = (byte) (toByte(achar[pos]) << 4 | toByte(achar[pos + 1])); 

return result; 

private static byte toByte(char c) 

byte b = (byte) "0123456789abcdef".indexOf(c); 
return b; 
}

*******************************

Android MD5加密算与J2SE平台一模一样,因为Android 平台支持 java.security.MessageDigest这个包。实际上与J2SE平台一模一样。

算法签名:

[java] view plaincopy
  1. String getMD5(String val) throws NoSuchAlgorithmException  
输入一个String(需要加密的文本),得到一个加密输出String(加密后的文本

[java] view plaincopy
  1. package com.tencent.utils;  
  2.   
  3. import java.security.MessageDigest;  
  4. import java.security.NoSuchAlgorithmException;  
  5. /** 
  6.  * 对外提供getMD5(String)方法 
  7.  * @author randyjia 
  8.  * 
  9.  */  
  10. public class MD5 {  
  11.       
  12.     public static String getMD5(String val) throws NoSuchAlgorithmException{  
  13.         MessageDigest md5 = MessageDigest.getInstance("MD5");  
  14.         md5.update(val.getBytes());  
  15.         byte[] m = md5.digest();//加密  
  16.         return getString(m);  
  17. }  
  18.     private static String getString(byte[] b){  
  19.         StringBuffer sb = new StringBuffer();  
  20.          for(int i = 0; i < b.length; i ++){  
  21.           sb.append(b[i]);  
  22.          }  
  23.          return sb.toString();  
  24. }  
  25. }  

结束


  1. /* 
  2. * MD5加密 
  3. */  
  4.   private String getMD5Str(String str) {       
  5.       MessageDigest messageDigest = null;       
  6.      
  7.       try {       
  8.           messageDigest = MessageDigest.getInstance("MD5");       
  9.      
  10.           messageDigest.reset();       
  11.      
  12.           messageDigest.update(str.getBytes("UTF-8"));       
  13.       } catch (NoSuchAlgorithmException e) {       
  14.           System.out.println("NoSuchAlgorithmException caught!");       
  15.           System.exit(-1);       
  16.       } catch (UnsupportedEncodingException e) {       
  17.           e.printStackTrace();       
  18.       }       
  19.      
  20.       byte[] byteArray = messageDigest.digest();       
  21.      
  22.       StringBuffer md5StrBuff = new StringBuffer();       
  23.         
  24.       for (int i = 0; i < byteArray.length; i++) {                   
  25.           if (Integer.toHexString(0xFF & byteArray[i]).length() == 1)       
  26.               md5StrBuff.append("0").append(Integer.toHexString(0xFF & byteArray[i]));       
  27.           else       
  28.               md5StrBuff.append(Integer.toHexString(0xFF & byteArray[i]));       
  29.       }       
  30.     //16位加密,从第9位到25位  
  31.       return md5StrBuff.substring(824).toString().toUpperCase();      
  32.   }  

0 0
原创粉丝点击