当前位置: 首页 > 编程笔记 >

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

阎劲
2023-03-14
本文向大家介绍Java加密 消息摘要算法SHA实现详解,包括了Java加密 消息摘要算法SHA实现详解的使用技巧和注意事项,需要的朋友参考一下

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。

 类似资料:
  • 本文向大家介绍Java加密 消息摘要算法MAC实现详解,包括了Java加密 消息摘要算法MAC实现详解的使用技巧和注意事项,需要的朋友参考一下 MAC是消息摘要算法的第三种实现方式,另外两种方式分别为:MD2\4\5、SHA。 MAC的jdk实现:1、默认密钥方式 2、动态密钥方式: MAC的BC实现: 到今天JAVA中的Base64、对称加密、消息摘要加密的实现总结就完工了,如果哪位对此感兴趣,

  • 本文向大家介绍Java 信息摘要加密MD2、MD4、MD5实现详解,包括了Java 信息摘要加密MD2、MD4、MD5实现详解的使用技巧和注意事项,需要的朋友参考一下 对于用户数据的保密一直是各个互联网企业头疼的事,那如何防止用户的个人信息泄露呢?今天为大家介绍一种最简单的加密方式--信息摘要算法MD。它如何来保护用户的个人信息呢?其实很简单,当获得到用户的信息后,先对其进行加密,然后将加密的结果

  • 本文向大家介绍Java消息摘要算法MAC实现与应用完整示例,包括了Java消息摘要算法MAC实现与应用完整示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Java消息摘要算法MAC实现与应用。分享给大家供大家参考,具体如下: 一 介绍 MAC:Message Authentication Code HMAC:keyed-Hash Message Authencication Code,

  • 本文向大家介绍JavaScript实现SHA-1加密算法的方法,包括了JavaScript实现SHA-1加密算法的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了JavaScript实现SHA-1加密算法的方法。分享给大家供大家参考。具体实现方法如下: 调用方法:hex_sha1即可。 希望本文所述对大家的javascript程序设计有所帮助。

  • 本文向大家介绍java 对称加密算法实现详解,包括了java 对称加密算法实现详解的使用技巧和注意事项,需要的朋友参考一下 前言 对于信息的加密方式多种多样,之前为大家介绍了一种自己设计的加密方式,有兴趣的朋友可以欣赏一下,欢迎给予指点。今天为大家介绍一下对称加密方式,所谓对称加密指的是加密和解密方式呈对称格式,即解密是加密的逆过程,下面我们就看一下:DES、3DES、AES、PBE这四种方式,他

  • Java安全加密专题文章索引 Java安全加密:对称加密 Java安全加密:非对称加密 Java安全加密:消息摘要Message Digest Java安全加密:数字签名和数字证书 Java安全加密:Https编程 1. 常见算法 MD5(已经被攻破)、SHA(sha1,sha256,sha512)、CRC、SM系列等 2. 使用场景 对用户密码进行md5 加密后保存到数据库里 软件下载站使用消息