Java加密 消息摘要算法SHA实现详解
SHA是消息摘要算法的一种实现方式,前面已经总结过MD2\4\5的实现,接下来就为大家总结一下SHA的实现。
SHA的jdk实现:
privatestaticvoidSHA_JDK(){ try{ MessageDigestdigest=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(NoSuchAlgorithmExceptione){ e.printStackTrace(); } }
SHA的BC实现:
privatestaticvoidSHA_BC(){ Digestdigest=newSHA1Digest(); digest.update(src.getBytes(),0,src.getBytes().length); byte[]shaByte=newbyte[digest.getDigestSize()]; digest.doFinal(shaByte,0); System.out.println("shaByte:"+Hex.encodeHexString(shaByte)); }
对于SHA224,JAVAjdk并没有提供实现,下面是利用BC实现的方法:
privatestaticvoidSHA224_BC(){ Digestdigest=newSHA224Digest(); digest.update(src.getBytes(),0,src.getBytes().length); byte[]sha224Byte=newbyte[digest.getDigestSize()]; digest.doFinal(sha224Byte,0); System.out.println("sha224Byte:"+Hex.encodeHexString(sha224Byte)); }
对于SHA224还有一种类似JDK的实现方法:
privatestaticvoidSHA224_BC_JDK(){ Security.addProvider(newBouncyCastleProvider()); try{ MessageDigestdigest=MessageDigest.getInstance("SHA-224"); digest.update(src.getBytes()); System.out.println("SHA224_BC_JDK:"+Hex.encodeHexString(digest.digest())); }catch(NoSuchAlgorithmExceptione){ e.printStackTrace(); } }
最后简单介绍一下CC的SHA实现:
privatestaticvoidSHA_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())); } privatestaticvoidSHA_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的实现总结完毕。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。