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

简介: 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"));
  }
}


相关文章
|
20天前
|
算法 数据安全/隐私保护
对称密钥加密算法和公开密钥加密算法有什么区别
【4月更文挑战第19天】对称密钥和公开密钥加密算法各有特点:对称密钥加密速度快,适用于大量数据,但密钥管理困难;公开密钥加密安全性高,密钥管理方便,但速度慢,常用于数字签名和身份验证。两者在不同场景下有不同优势。
31 6
|
2月前
|
算法 Java 数据安全/隐私保护
java MD5 32位加密
java MD5 32位加密
19 0
|
11天前
|
算法 安全 Java
性能工具之 JMeter 自定义 Java Sampler 支持国密 SM2 算法
【4月更文挑战第28天】性能工具之 JMeter 自定义 Java Sampler 支持国密 SM2 算法
26 1
性能工具之 JMeter 自定义 Java Sampler 支持国密 SM2 算法
|
2月前
|
存储 算法 Java
Java数据结构与算法-java数据结构与算法(二)
Java数据结构与算法-java数据结构与算法
120 1
|
15天前
|
安全 算法 网络安全
|
17天前
|
设计模式 算法 Java
[设计模式Java实现附plantuml源码~行为型]定义算法的框架——模板方法模式
[设计模式Java实现附plantuml源码~行为型]定义算法的框架——模板方法模式
|
18天前
|
搜索推荐 算法 Java
Java实现的常用八种排序算法
提到数据结构与算法,无法避免的一点就包含排序,熟练的掌握各种排序算法则是一个程序员必备的素质之一,除此之外,排序算法也是当下各大技术公司比较喜欢问的技术点,所以,就这一点JavaBuild整理了常见的8种排序算法
7 0
|
22天前
|
机器学习/深度学习 数据采集 算法
使用 Java 实现机器学习算法
【4月更文挑战第19天】Java在数据驱动时代为机器学习提供支持,具备丰富的数学和数据结构库,适用于实现线性回归、决策树、SVM和随机森林等算法。实现时注意数据预处理、模型选择、评估指标和可视化。利用Java的库和编程能力可构建高效模型,但需按问题需求选择合适技术和优化方法。
|
1月前
|
算法 安全 Java
java代码 实现AES_CMAC 算法测试
该代码实现了一个AES-CMAC算法的简单测试,使用Bouncy Castle作为安全提供者。静态变量K定义了固定密钥。`Aes_Cmac`函数接受密钥和消息,返回AES-CMAC生成的MAC值。在`main`方法中,程序对给定的消息进行AES-CMAC加密,然后模拟接收ECU的加密结果并进行比较。如果两者匹配,输出&quot;验证成功&quot;,否则输出&quot;验证失败&quot;。辅助方法包括将字节转为16进制字符串和将16进制字符串转为字节。
|
1月前
|
Java 数据安全/隐私保护
java base64 加密 解密
java base64 加密 解密