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"));
}
}
以上就是本文的全體內容,願望對年夜家的進修有所贊助,也願望年夜家多多支撐。