winform獲得以後稱號實例匯總。本站提示廣大學習愛好者:(winform獲得以後稱號實例匯總)文章只能為提供參考,不一定能成為您想要的結果。以下是winform獲得以後稱號實例匯總正文
本篇應用java自帶的MessageDigest完成對文本的md5加密算法,詳細代碼以下:
/** *@Description: 將字符串轉化為MD5 */ package cn.yicha.novel.util; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; public class ParseMD5 { /** * @param str * @return * @Description: 32位小寫MD5 */ public static String parseStrToMd5L32(String str){ String reStr = null; try { MessageDigest md5 = MessageDigest.getInstance("MD5"); byte[] bytes = md5.digest(str.getBytes()); StringBuffer stringBuffer = new StringBuffer(); for (byte b : bytes){ int bt = b&0xff; if (bt < 16){ stringBuffer.append(0); } stringBuffer.append(Integer.toHexString(bt)); } reStr = stringBuffer.toString(); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } return reStr; } /** * @param str * @return * @Description: 32位年夜寫MD5 */ public static String parseStrToMd5U32(String str){ String reStr = parseStrToMd5L32(str); if (reStr != null){ reStr = reStr.toUpperCase(); } return reStr; } /** * @param str * @return * @Description: 16位小寫MD5 */ public static String parseStrToMd5U16(String str){ String reStr = parseStrToMd5L32(str); if (reStr != null){ reStr = reStr.toUpperCase().substring(8, 24); } return reStr; } /** * @param str * @return * @Description: 16位年夜寫MD5 */ public static String parseStrToMd5L16(String str){ String reStr = parseStrToMd5L32(str); if (reStr != null){ reStr = reStr.substring(8, 24); } return reStr; } }
第二種情形:在停止Java軟件開辟進程中,不免會對一些數據停止加密,是以Java中供給了自帶的MessageDigest完成對文本的加密算法,上面是一個對文本停止加密的MD5加密對象類代碼示例:
Java中的MD5加密算法完全版:
package net.yuerwan.commons.util; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import org.apache.commons.lang.StringUtils; 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(); }
第三種情形:MD5加密算法的java完成
package other; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; /* * MD5 算法 */ public class MD5 { // 全局數組 private final static String[] strDigits = { "0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "a", "b", "c", "d", "e", "f" }; public MD5() { } // 前往情勢為數字跟字符串 private static String byteToArrayString(byte bByte) { int iRet = bByte; // System.out.println("iRet="+iRet); if (iRet < 0) { iRet += 256; } int iD1 = iRet / 16; int iD2 = iRet % 16; return strDigits[iD1] + strDigits[iD2]; } // 前往情勢只為數字 private static String byteToNum(byte bByte) { int iRet = bByte; System.out.println("iRet1=" + iRet); if (iRet < 0) { iRet += 256; } return String.valueOf(iRet); } // 轉換字節數組為16進制字串 private static String byteToString(byte[] bByte) { StringBuffer sBuffer = new StringBuffer(); for (int i = 0; i < bByte.length; i++) { sBuffer.append(byteToArrayString(bByte[i])); } return sBuffer.toString(); } public static String GetMD5Code(String strObj) { String resultString = null; try { resultString = new String(strObj); MessageDigest md = MessageDigest.getInstance("MD5"); // md.digest() 該函數前往值為寄存哈希值成果的byte數組 resultString = byteToString(md.digest(strObj.getBytes())); } catch (NoSuchAlgorithmException ex) { ex.printStackTrace(); } return resultString; } public static void main(String[] args) { MD5 getMD5 = new MD5(); System.out.println(getMD5.GetMD5Code("000000")); } }