java自帶的MessageDigest實現文字的md5加密演算法
本篇使用java自帶的MessageDigest實現對文字的md5加密演算法,具體程式碼如下:
/**
*@Description: 將字串轉化為MD5
*/
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加密演算法完整版:
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(String Utils.isBlank(plainText)){
return null;
}
try{
//首先進行例項化和初始化
MessageDigest md = MessageDigest.getInstance("MD5");
//得到一個作業系統預設的位元組編碼格式的位元組陣列
byte[] btInput = plainText.getBytes();
//對得到的位元組陣列進行處理
md.update(btInput);
//進行雜湊計算並返回結果
byte[] btResult = md.digest();
//進行雜湊計算後得到的資料的長度
StringBuffer sb = newStringBuffer();
for(byteb : btResult){
intbt = 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實現
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"));
}
}