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 加密后保存到数据库里 软件下载站使用消息