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的实现总结完毕。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。