JAVA加解密6-消息摘要算法-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
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 本系列文章主要总结了常用的Java加解密技术。本文介绍消息摘要,包括MD、SHA和MAC,消息摘要是一种不可逆的过...
    awesome丁阅读 465评论 0 0
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,026评论 19 139
  • 由于计算机软件的非法复制,通信的泄密、数据安全受到威胁,解密及盗版问题日益严重,甚至引发国际争端,所以在信息安全技...
    慕涵盛华阅读 2,580评论 0 4
  • base64分两个:一个是base64针对邮件传输的算法。另外一个就是为了在浏览器中传送加密数据或者隐藏表单中用的...
    K1024阅读 717评论 1 0
  • 邻居火锅店试营业中…… 见一位大姐从店里出来,感觉差不多应该是老板娘。 “准备啥时候开业啊?”我说 “应该就这两天...
    大張冰阅读 150评论 0 5