java自帶的MessageDigest實現(xiàn)文本的md5加密算法
本篇使用java自帶的MessageDigest實現(xiàn)對文本的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軟件開發(fā)過程中,難免會對一些數(shù)據(jù)進行加密,因此Java中提供了自帶的MessageDigest實現(xiàn)對文本的加密算法,下面是一個對文本進行加密的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");
//得到一個操作系統(tǒng)默認的字節(jié)編碼格式的字節(jié)數(shù)組
byte[] btInput = plainText.getBytes();
//對得到的字節(jié)數(shù)組進行處理
md.update(btInput);
//進行哈希計算并返回結果
byte[] btResult = md.digest();
//進行哈希計算后得到的數(shù)據(jù)的長度
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實現(xiàn)
package other;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
/*
* MD5 算法
*/
public class MD5 {
// 全局數(shù)組
private final static String[] strDigits = { "0", "1", "2", "3", "4", "5",
"6", "7", "8", "9", "a", "b", "c", "d", "e", "f" };
public MD5() {
}
// 返回形式為數(shù)字跟字符串
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];
}
// 返回形式只為數(shù)字
private static String byteToNum(byte bByte) {
int iRet = bByte;
System.out.println("iRet1=" + iRet);
if (iRet < 0) {
iRet += 256;
}
return String.valueOf(iRet);
}
// 轉換字節(jié)數(shù)組為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() 該函數(shù)返回值為存放哈希值結果的byte數(shù)組
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"));
}
}
相關文章
Java封裝數(shù)組實現(xiàn)在數(shù)組中查詢元素和修改元素操作示例
這篇文章主要介紹了Java封裝數(shù)組實現(xiàn)在數(shù)組中查詢元素和修改元素操作,結合實例形式分析了java針對數(shù)組元素查詢、修改的封裝操作實現(xiàn)技巧,需要的朋友可以參考下2020-03-03
Mybatis中3種關聯(lián)關系的實現(xiàn)方法示例
這篇文章主要給大家介紹了關于Mybatis中3種關聯(lián)關系的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者使用Mybatis具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧2019-11-11
java哈希算法HashMap經(jīng)典面試題目匯總解析
這篇文章主要為大家介紹了java哈希算法HashMap的經(jīng)典面試題目匯總及問題解析,幫助大家徹底征服面試官,實現(xiàn)薪資自由,有需要的朋友可以借鑒參考下,希望能夠有所幫助2022-03-03
解決使用stream將list轉map時,key重復導致報錯的問題
這篇文章主要介紹了解決使用stream將list轉map時,key重復導致報錯的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-06-06

