java MD5加密完成代碼。本站提示廣大學習愛好者:(java MD5加密完成代碼)文章只能為提供參考,不一定能成為您想要的結果。以下是java MD5加密完成代碼正文
先從上面這張圖對MD5加密完成停止懂得,詳細以下
package com.pb; import java.io.UnsupportedEncodingException; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import java.util.Scanner; /* * 驗證MD5 * 1.初始化MessageDigest信息摘要對象 * 2.傳入須要盤算的字符串更新摘要信息 * 3.盤算信息摘要 * 4.將byte[] 轉換為找度為32位的16進制字符串 */ public class MD5 { /* * 生成md5 有傳入參數字符串 */ public void generateMD5(String input){ try { //1.初始化MessageDigest信息摘要對象,並指定為MD5不分年夜小寫都可以 MessageDigest md=MessageDigest.getInstance("md5"); //2.傳入須要盤算的字符串更新摘要信息,傳入的為字節數組byte[], //將字符串轉換為字節數組應用getBytes()辦法完成 //指准時其字符編碼 為utf-8 md.update(input.getBytes("utf-8")); //3.盤算信息摘要digest()辦法 //前往值為字節數組 byte [] hashCode=md.digest(); //4.將byte[] 轉換為找度為32位的16進制字符串 //聲明StringBuffer對象來寄存最初的值 StringBuffer sb=new StringBuffer(); //遍歷字節數組 for(byte b:hashCode){ //對數組內容轉化為16進制, sb.append(Character.forDigit(b>>4&0xf, 16)); //換2次為32位的16進制 sb.append(Character.forDigit(b&0xf, 16)); } System.out.println("加密後的成果是:"+sb.toString()); } catch (NoSuchAlgorithmException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (UnsupportedEncodingException e) { // TODO Auto-generated catch block e.printStackTrace(); } } public static void main(String[] args) { //聲明加密MD5類的對象 MD5 md5=new MD5(); //應用Scanner來輸出一個字符 Scanner scanner=new Scanner(System.in); System.out.println("請輸出要加密的內容:"); String input = scanner.nextLine(); //挪用加密辦法 md5.generateMD5(input); } }
成果:
請輸出要加密的內容:
進修MD5加密進程
加密後的成果是:b826cdac46f01dcc8ccc60a76cebf858
第二段代碼:
package test.md5; import java.security.MessageDigest; public class MD5Util { public final static String MD5(String s) { char hexDigits[]={'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'}; try { byte[] btInput = s.getBytes(); // 取得MD5摘要算法的 MessageDigest 對象 MessageDigest mdInst = MessageDigest.getInstance("MD5"); // 應用指定的字節更新摘要 mdInst.update(btInput); // 取得密文 byte[] md = mdInst.digest(); // 把密文轉換成十六進制的字符串情勢 int j = md.length; char str[] = new char[j * 2]; int k = 0; for (int i = 0; i < j; i++) { byte byte0 = md[i]; str[k++] = hexDigits[byte0 >>> 4 & 0xf]; str[k++] = hexDigits[byte0 & 0xf]; } return new String(str); } catch (Exception e) { e.printStackTrace(); return null; } } public static void main(String[] args) { System.out.println(MD5Util.MD5("20121221")); System.out.println(MD5Util.MD5("加密")); } }
第三段代碼: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")); } }
以上就是本文的全體內容,願望對年夜家的進修有所贊助,也願望年夜家多多支撐。