软件编程
位置:首页>> 软件编程>> java编程>> java自带的MessageDigest实现文本的md5加密算法

java自带的MessageDigest实现文本的md5加密算法

作者:lijiao  发布时间:2023-10-08 03:35:29 

标签:java,MessageDigest,md5

本篇使用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"));
 }
}
0
投稿

猜你喜欢

手机版 软件编程 asp之家 www.aspxhome.com