Java中的MD5加密算法完整版

在進行Java軟件開發過程中,難免會對一些數據進行加密,因此Java中提供了自帶的MessageDigest實現對文本的加密算法,下面是一個對文本進行加密的MD5加密工具類代碼示例:


package net.yuerwan.commons.util; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import org.apache.commons.lang.StringUtils; /** * 功能:MD5加密工具類 * 說明:轉載請註明:文波の小站---http://www.iwwenbo.com */ public class MD5Util { /** * 1.對文本進行32位小寫MD5加密 * @param plainText 要進行加密的文本 * @return 加密後的內容 */ public static String textToMD5L32(String plainText){ String result = null; //首先判斷是否爲空 if(StringUtils.isBlank(plainText)){ return null; } try{ //首先進行實例化和初始化 MessageDigest md = MessageDigest.getInstance("MD5"); //得到一個操作系統默認的字節編碼格式的字節數組 byte[] btInput = plainText.getBytes(); //對得到的字節數組進行處理 md.update(btInput); //進行哈希計算並返回結果 byte[] btResult = md.digest(); //進行哈希計算後得到的數據的長度 StringBuffer sb = new StringBuffer(); for(byte b : btResult){ int bt = b&0xff; if(bt<16){ sb.append(0); } sb.append(Integer.toHexString(bt)); } result = sb.toString(); }catch(NoSuchAlgorithmException e){ e.printStackTrace(); } return result; } /** * 2.對文本進行32位MD5大寫加密 * @param plainText 要進行加密的文本 * @return 加密後的內容 */ public static String textToMD5U32(String plainText){ if(StringUtils.isBlank(plainText)){ return null; } String result = textToMD5L32(plainText); return result.toUpperCase(); }

/** *3.對文本進行16位MD5小寫加密 *@param plainText需要進行加密的文本 * */ public static String textToMD5L16(String plainText) { if (StringUtils.isBlank(plainText)) { return null; } String result = textToMD5L32(plainText); return result.substring(8, 24); }

/** *4.對文本進行16位MD5小寫加密 *@param plainText需要進行加密的文本 *@return */ public static String textToMD5L16(String plainText) { if (StringUtils.isBlank(plainText)) { return null; } String result = textToMD5L32(plainText); return result.toUpperCase().substring(8, 24); }

public static void main(String[] args) { System.out.println(textToMD5L16("0")); } }

 

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