欢迎来到代码驿站!

JAVA代码

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

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

时间:2021-02-27 14:31:50|栏目:JAVA代码|点击:

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的实现总结完毕。

上一篇:SpringBoot使用Mybatis-Generator配置过程详解

栏    目:JAVA代码

下一篇:Java跨域问题的处理详解

本文标题:Java加密 消息摘要算法SHA实现详解

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

推荐教程

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

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

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

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

Copyright © 2020 代码驿站 版权所有