消息摘要算法-bouncy castle支持的MD4算法扩展-阿里云开发者社区

开发者社区> 王爵nice> 正文

消息摘要算法-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

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
NOIP-C++大神培养计划 Step1.1.2基础算法——模拟算法2
大家好,我是小笨笨,今天我们继续来讲解模拟算法。 我们直接上例题! 栗1.1.2-1 洛谷P1014 Cantor表https://www.luogu.org/problemnew/show/P1014题目描述现代数学的著名证明之一是Georg Cantor证明了有理数是可枚举的。
987 0
【ECS】好消息,弹性网卡支持添加辅助私网IP啦
背景 阿里云的ECS服务器,很早就支持了多网卡的挂载,卸载。近日我们又推出了新功能,每块弹性网卡又支持分配和回收多辅助私网IP地址啦。 实例列表页以及详情页支持管理主网卡的辅助私网IP 在实例列表页,在每一个实例的操作栏里点击 更多 -> 网络和安全组 -> 管理辅助私网IP,可看到,弹出了相应的...
4406 0
RocketMQ系列(五)广播与延迟消息
今天要给大家介绍RocketMQ中的两个功能,一个是“广播”,这个功能是比较基础的,几乎所有的mq产品都是支持这个功能的;另外一个是“延迟消费”,这个应该算是RocketMQ的特色功能之一了吧。
465 0
C# 让RichTextBox支持GIF
我只是做了一些简单的测试...有疑问给我发消息把. 使用方法 //获取选择的图形 并且保存出来 private void button2_Click(object sender, EventArgs e)    ...
852 0
《算法设计编程实验:大学程序设计课程与竞赛训练教材》——导读
全书以知识单元为基本构件,各单元既保持循序渐进的顺序又相对独立,既可拆卸重组、各取所需,又可在此基础上推广或创新,便于各学校按照不同的层次要求组织教学和培训活动。
755 0
NOIP-C++大神培养计划Step1.1.1基础算法——模拟算法1
模拟算法,可以说是最基础的算法了。它的基本定义没太多意思:就是去模拟题目的要求。题意要你怎么做,你就怎么做,看懂了题目,基本上就会做了。 举一个大家耳熟能详的栗子。 A+B Problem给定两个整数A和B,输出他们的和。
1249 0
+关注
王爵nice
https://github.com/biezhi
164
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载