欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

Java 信息摘要加密MD2、MD4、MD5实现详解

时间:2022-07-23 10:00:16|栏目:JAVA代码|点击:

对于用户数据的保密一直是各个互联网企业头疼的事,那如何防止用户的个人信息泄露呢?今天为大家介绍一种最简单的加密方式--信息摘要算法MD。它如何来保护用户的个人信息呢?其实很简单,当获得到用户的信息后,先对其进行加密,然后将加密的结果保存到数据库,这样即使被盗,用户的数据也不会丢失。下面上代码:

JAVA的jdk提供了MD2和MD5的加密方式, JAVA不支持MD4的jdk加密方式,jdk的实现如下:

private static void MD2_jdk(){
    try {
      MessageDigest digest = MessageDigest.getInstance("MD2");//获得消息摘要MD2对象
      byte[] md2Byte = digest.digest(src.getBytes());
      System.out.println("md2Byte :"+md2Byte.toString());
      System.out.println("md2Byte :"+Hex.encodeHexString(md2Byte));
    } catch (NoSuchAlgorithmException e) {
      e.printStackTrace();
    }  
  }
  
  private static void MD5_jdk(){
    try {
      MessageDigest digest = MessageDigest.getInstance("MD5");//获得消息摘要MD5对象
      byte[] md5Byte = digest.digest(src.getBytes());
      System.out.println("md5Byte :"+md5Byte.toString());
      System.out.println("md5Byte :"+Hex.encodeHexString(md5Byte));
    } catch (NoSuchAlgorithmException e) {
      e.printStackTrace();
    }
  }

bc提供了MD2\4\5的加密实现(bc使用需要添加bc的jar包):

private static void MD2_bc(){
    Digest digest = new MD2Digest();//通过BC获得消息摘要MD2对象
    digest.update(src.getBytes(), 0, src.getBytes().length);
    byte[] md2Byte = new byte[digest.getDigestSize()];
    digest.doFinal(md2Byte, 0);
    System.out.println("md2Byte :"+md2Byte.toString());
    System.out.println("md2Byte : "+org.bouncycastle.util.encoders.Hex.toHexString(md2Byte));
  }
  
  private static void MD4_bc(){
    Digest digest = new MD4Digest();//通过BC获得消息摘要MD4对象
    digest.update(src.getBytes(), 0, src.getBytes().length);
    byte[] md4Byte = new byte[digest.getDigestSize()];
    digest.doFinal(md4Byte, 0);
    System.out.println("md4Byte :"+md4Byte.toString());
    System.out.println("md4Byte : "+org.bouncycastle.util.encoders.Hex.toHexString(md4Byte));
  }
  
  private static void MD5_bc(){
    Digest digest = new MD5Digest();//通过BC获得消息摘要MD5对象
    digest.update(src.getBytes(), 0, src.getBytes().length);
    byte[] md5Byte = new byte[digest.getDigestSize()];
    digest.doFinal(md5Byte, 0);
    System.out.println("md5Byte :"+md5Byte.toString());
    System.out.println("md5Byte : "+org.bouncycastle.util.encoders.Hex.toHexString(md5Byte));
  }

通过bc为jdk添加一个动态的MD4方法:

private static void MD4_bc_jdk(){
    try {
      Security.addProvider(new BouncyCastleProvider());
      MessageDigest md = MessageDigest.getInstance("MD4");
      byte[] md4Byte = md.digest(src.getBytes());
      System.out.println("md4Byte :"+md4Byte.toString());
      System.out.println("md4Byte :"+Hex.encodeHexString(md4Byte));
    } catch (NoSuchAlgorithmException e) {
      e.printStackTrace();
    }
  }

最后为大家介绍一下CC的MD2\5的实现:

DigestUtils.md2Hex(src.getBytes());
DigestUtils.md5Hex(src.getBytes());

注:src为设置的一个字符串。

到这里消息摘要加密算法的MD2\4\5的实现到此讲解完毕,对Base64和对称加密算法有兴趣的朋友可以看一下我之前分享的博客。小生很喜欢信息安全,那位有兴趣,欢迎交流。(1453296946@qq.com)

上一篇:在Eclipse中更改maven项目名的方法

栏    目:JAVA代码

下一篇:Springboot整合企业微信机器人助手推送消息的实现

本文标题:Java 信息摘要加密MD2、MD4、MD5实现详解

本文地址:http://www.codeinn.net/misctech/208640.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有