消息摘要算法-bouncy castle支持的MD4算法扩展

简介:

sun本身支持MD2和MD5,但是缺少进制转换与支持

 

bouncy castle对sun进行支持补充,提供了对MD4的算法,同时对十六进制转换提供了支持。

 

commons codec 只是针对MD5支持,并且支持16进制

 

但是大部分场景下我们都是使用MD5,毕竟MD5是经过MD4改良进来了。不过也有场景可能会用到MD4。那我们就将MD4消息摘要处理的代码展示下:

package com.ca.test;
import java.security.MessageDigest;
import java.security.Security;
import org.bouncycastle.jce.provider.BouncyCastleProvider;
import org.bouncycastle.util.encoders.Hex;
/**
 * bouncy castle扩展支持的MD4的算法实现
 * @author kongqz
 * */
public class MD4Coder {
	
	
	/**
	 * MD4的消息摘要算法实现
	 * @param data 要做消息摘要的数据
	 * @return byte[] 消息摘要
	 * 
	 * */
	public static byte[] encodeMD4(byte[] data) throws Exception{
		
		Security.addProvider(new BouncyCastleProvider());
		//初始化MessageDigest
		MessageDigest md=MessageDigest.getInstance("MD4");
		
		return md.digest(data);
	}
	
	/**
	 * MD4的消息摘要算法实现,转成16进制
	 * @param data 要做消息摘要的数据
	 * @return String 消息摘要
	 * 
	 * */
	public static String encodeMD4Hex(byte[] data) throws Exception{
		
		byte[] b= encodeMD4(data);
		
		return new String(Hex.encode(b));
	}
	/**
	 * @param args
	 * @throws Exception 
	 */
	public static void main(String[] args) throws Exception {
		String str="bouncycast 的消息摘要算法";
		System.out.println("原文:"+str);
		byte[] data1=MD4Coder.encodeMD4(str.getBytes());
		System.out.println("MD4的消息摘要算法值:"+data1.toString());
		
		String data2=MD4Coder.encodeMD4Hex(str.getBytes());
		System.out.println("MD4做十六进制编码处理的消息摘要算法值:"+data2);
		
		
	}
}
控制台输出如下:
原文:bouncycast 的消息摘要算法
MD4的消息摘要算法值:[B@bfbdb0
MD4做十六进制编码处理的消息摘要算法值:ef11e6aed3adabbcc2e24f0ef7822570

目录
相关文章
|
8月前
|
算法
class072 最长递增子序列问题与扩展【算法】
class072 最长递增子序列问题与扩展【算法】
61 0
|
8月前
|
算法
class071 子数组最大累加和问题与扩展-下【算法】
class071 子数组最大累加和问题与扩展-下【算法】
62 0
|
8月前
|
算法 数据处理 C++
【C++ 20 新特性 算法和迭代器库的扩展和泛化 Ranges】深入浅出C++ Ranges库 (Exploring the C++ Ranges Library)
【C++ 20 新特性 算法和迭代器库的扩展和泛化 Ranges】深入浅出C++ Ranges库 (Exploring the C++ Ranges Library)
945 1
|
20天前
|
JSON 算法 Java
Nettyの网络聊天室&扩展序列化算法
通过本文的介绍,我们详细讲解了如何使用Netty构建一个简单的网络聊天室,并扩展序列化算法以提高数据传输效率。Netty的高性能和灵活性使其成为实现各种网络应用的理想选择。希望本文能帮助您更好地理解和使用Netty进行网络编程。
37 12
|
7月前
|
机器学习/深度学习 算法 搜索推荐
【初阶算法4】——归并排序的详解,及其归并排序的扩展
【初阶算法4】——归并排序的详解,及其归并排序的扩展
【初阶算法4】——归并排序的详解,及其归并排序的扩展
|
4月前
|
资源调度 算法
基于迭代扩展卡尔曼滤波算法的倒立摆控制系统matlab仿真
本课题研究基于迭代扩展卡尔曼滤波算法的倒立摆控制系统,并对比UKF、EKF、迭代UKF和迭代EKF的控制效果。倒立摆作为典型的非线性系统,适用于评估不同滤波方法的性能。UKF采用无迹变换逼近非线性函数,避免了EKF中的截断误差;EKF则通过泰勒级数展开近似非线性函数;迭代EKF和迭代UKF通过多次迭代提高状态估计精度。系统使用MATLAB 2022a进行仿真和分析,结果显示UKF和迭代UKF在非线性强的系统中表现更佳,但计算复杂度较高;EKF和迭代EKF则更适合维数较高或计算受限的场景。
|
4月前
|
算法 数据安全/隐私保护 C++
超级好用的C++实用库之MD5信息摘要算法
超级好用的C++实用库之MD5信息摘要算法
110 0
|
5月前
|
算法 JavaScript 前端开发
消息摘要算法:MD5加密
消息摘要算法:MD5加密
70 1
|
6月前
|
算法 安全 数据安全/隐私保护
支付系统---微信支付09------数字签名,现在Bob想要给Pink写一封信,信件的内容不需要加密,怎样能够保证信息的完整性,使用信息完整性的主要手段是摘要算法,散列函数,哈希函数,H称为数据指纹
支付系统---微信支付09------数字签名,现在Bob想要给Pink写一封信,信件的内容不需要加密,怎样能够保证信息的完整性,使用信息完整性的主要手段是摘要算法,散列函数,哈希函数,H称为数据指纹
|
8月前
|
算法 数据安全/隐私保护
什么是扩展欧几里得算法?
【5月更文挑战第13天】什么是扩展欧几里得算法?
130 3

热门文章

最新文章