Java加密 消息摘要算法SHA实现详解

发布时间:2020-09-12 22:05:20 作者:小破孩123
来源:脚本之家 阅读:182

SHA是消息摘要算法的一种实现方式,前面已经总结过MD2\4\5的实现,接下来就为大家总结一下SHA的实现。

SHA的jdk实现:

private static void SHA_JDK(){
    try {
      MessageDigest digest = MessageDigest.getInstance("SHA");//我们可以通过SHA\SHA-1\SHA-384\SHA-256\SHA-512来获得不同的消息摘要密钥
      digest.update(src.getBytes());
      System.out.println("SHA :"+Hex.encodeHexString(digest.digest()));
    } catch (NoSuchAlgorithmException e) {
      e.printStackTrace();
    }
  }

SHA的BC实现:

private static void SHA_BC(){
    Digest digest = new SHA1Digest();
    digest.update(src.getBytes(), 0, src.getBytes().length);
    byte[] shaByte = new byte[digest.getDigestSize()];
    digest.doFinal(shaByte, 0);
    System.out.println("shaByte : "+Hex.encodeHexString(shaByte));
  }

对于SHA224,JAVA jdk并没有提供实现,下面是利用BC实现的方法:

private static void SHA224_BC(){
    Digest digest = new SHA224Digest();
    digest.update(src.getBytes(), 0, src.getBytes().length);
    byte[] sha224Byte = new byte[digest.getDigestSize()];
    digest.doFinal(sha224Byte, 0);
    System.out.println("sha224Byte : "+Hex.encodeHexString(sha224Byte));
  }

对于SHA224还有一种类似JDK的实现方法:

private static void SHA224_BC_JDK(){
    Security.addProvider(new BouncyCastleProvider());
    try {
      MessageDigest digest = MessageDigest.getInstance("SHA-224");
      digest.update(src.getBytes());
      System.out.println("SHA224_BC_JDK :"+Hex.encodeHexString(digest.digest()));
    } catch (NoSuchAlgorithmException e) {
      e.printStackTrace();
    }
  }

最后简单介绍一下CC的SHA实现:

private static void SHA_CC_Byte(){
    System.out.println("SHA_CC_Byte_SHA1 : "+DigestUtils.sha1Hex(src.getBytes()));
    System.out.println("SHA_CC_Byte_SHA256 : "+DigestUtils.sha256Hex(src.getBytes()));
    System.out.println("SHA_CC_Byte_SHA384 : "+DigestUtils.sha384Hex(src.getBytes()));
    System.out.println("SHA_CC_Byte_SHA512 : "+DigestUtils.sha512Hex(src.getBytes()));
  }
   
  private static void SHA_CC(){
    System.out.println("SHA_CC_SHA1 : "+DigestUtils.sha1Hex(src));
    System.out.println("SHA_CC_SHA256 : "+DigestUtils.sha256Hex(src));
    System.out.println("SHA_CC_SHA384 : "+DigestUtils.sha384Hex(src));
    System.out.println("SHA_CC_SHA512 : "+DigestUtils.sha512Hex(src));
  }

到这里SHA的实现总结完毕。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持亿速云。

推荐阅读:
  1. 常用的加密算法---数字摘要
  2. Java加密与安全

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

java 加密 消息摘要

上一篇:对dbunit进行mybatis DAO层Excel单元测试(必看篇)

下一篇:linux中权限管理命令详解(chmod/chown/chgrp/unmask)

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》