MD5加密簡(jiǎn)介
哈希算法又稱散列算法,是將任何數(shù)據(jù)轉(zhuǎn)換成固定長(zhǎng)度的算法的統(tǒng)稱。 從本質(zhì)上講,MD5也是一種哈希算法炕桨,其輸出是生成128位的輸出結(jié)果饭尝。 如果輸入兩個(gè)不同的明文,就會(huì)輸出兩個(gè)不同的輸出值献宫,并且根據(jù)輸出值钥平,不能得到原始的明文,這個(gè)過程是不可逆的姊途。
MD5加密原理
MD5算法對(duì)512位報(bào)文的輸入信息進(jìn)行處理涉瘾,每個(gè)報(bào)文被分成16個(gè)32位報(bào)文。 經(jīng)過一系列處理后捷兰,算法的輸出由4個(gè)32位的數(shù)據(jù)包組成立叛,這些數(shù)據(jù)包能聯(lián)生成一個(gè)128位的哈希值。
在MD5算法中贡茅,信息的填寫方式是這樣的:消息后面跟著一個(gè)1秘蛇,然后是無數(shù)個(gè)0,直到512字節(jié)的剩余數(shù)等于448 (n*512) + 448顶考。 為什么剩下的是448赁还,因?yàn)槭O碌?12-448是64位,表示填充前的消息長(zhǎng)度驹沿。 加上剩下的64位艘策,(n+1)乘以512,也就是512的整數(shù)倍渊季。
然后循環(huán)通過link變量獲得結(jié)果朋蔫。 MD5包含四個(gè)32位整數(shù)參數(shù),稱為鏈接變量:A=0x01234567, B= 0x89ABCdef, C= 0xFeDCba98, D=0x76543210却汉。 一旦設(shè)置好四個(gè)鏈接變量斑举,算法就開始了四輪循環(huán)。 具體的內(nèi)部計(jì)算是關(guān)于數(shù)學(xué)的病涨。如果你感興趣富玷,你可以自己理解。這里沒有更多的解釋。
MD5加密常用方法
/**
* 用MD5算法進(jìn)行加密
* @param str 需要加密的字符串
* @return MD5加密后的結(jié)果
* @throws UnsupportedEncodingException
*/
public static String encodeMD5String(String str) {
return getMD5(str);
}
復(fù)制代碼
/**
* MD5編碼方法赎懦, 該方法存在漏洞雀鹃,特殊情況下編碼后的字符串只有31位長(zhǎng)度
* @param str
* @param method
* @return
* @throws UnsupportedEncodingException
*/
private static String encode(String str, String method) throws UnsupportedEncodingException {
MessageDigest md = null;
String dstr = null;
try {
md = MessageDigest.getInstance(method);
md.update(str.getBytes("UTF-8"));
dstr = new BigInteger(1, md.digest()).toString(16);
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
return dstr;
}
復(fù)制代碼
/**
* MD5編碼方法
* @param message
* @return
*/
public static String getMD5(String message) {
MessageDigest messageDigest = null;
StringBuffer md5StrBuff = new StringBuffer();
try {
messageDigest = MessageDigest.getInstance("MD5");
messageDigest.reset();
messageDigest.update(message.getBytes("UTF-8"));
byte[] byteArray = messageDigest.digest();
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]));
}
} catch (Exception e) {
throw new RuntimeException();
}
return md5StrBuff.toString().toUpperCase();//字母大寫
}
復(fù)制代碼
/**
* 加密
* @param content
* @return
*/
public static String encrypt(String content) {
String password = "12345678dd";
byte[] encryptResult = encrypt(content, password);
String encryptResultStr = parseByte2HexStr(encryptResult);
return encryptResultStr;
}
復(fù)制代碼
/**
* 加密
* @param content
* @param password
* @return
*/
public static String encryptStr(String content, String password) {
byte[] encryptResult = encrypt(content, password);
return parseByte2HexStr(encryptResult);
}
復(fù)制代碼
/**
* 解密
* @param encryptResultStr
* @return
* @throws UnsupportedEncodingException
*/
public static String decrypt(String encryptResultStr) throws UnsupportedEncodingException {
String password = "12345678dd";
byte[] decryptFrom = parseHexStr2Byte(encryptResultStr);
byte[] decryptResult = decrypt(decryptFrom, password);
// 解密內(nèi)容進(jìn)行解碼
String result = new String(decryptResult, UTF8);
return result;
}
復(fù)制代碼
/**
* 解密
* @param encryptStr
* @param password
* @return
* @throws UnsupportedEncodingException
*/
public static String decryptStr(String encryptStr, String password) throws UnsupportedEncodingException {
byte[] decryptFrom = parseHexStr2Byte(encryptStr);
byte[] decryptResult = decrypt(decryptFrom, password);
// 解密內(nèi)容進(jìn)行解碼
return new String(decryptResult, UTF8);
}