信息加密之消息摘要算法的SHA
2024-08-24 18:36:34
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的实现总结完毕。
最新文章
- Asp.net窄屏页面 手机端新闻列表
- CRT注册工具使用说明
- api-ms-win-crt-runtimel1-1-0.dll缺失的解决方案
- Part 67 to 70 Talking about method parameters in C#
- Swift入坑--block的定义
- Leetcode 283 Move Zeroes python
- VSTO学习笔记(五)批量编辑Excel 2010 x64
- ecshop中getAll ,getOne ,getRow的区别
- Linux shell 操作 postgresql,并设置crontab任务
- 2016 ICPC总结
- 《Python网络编程》学习笔记--使用谷歌地理编码API获取一个JSON文档
- CF434D Nanami's Power Plant 最小割
- Centos 04 基础系统优化命令
- ZooKeeper-3.3.4集群安装配置
- [HNOI2018]游戏[拓扑排序]
- Java 输入/输出——处理流(DataInputStream/DataOutputStream、ByteArrayInputStream/ByteArrayOutputStream)
- centos 监控进程,并自动重启
- 快速理解RequireJs(转)
- Mosquitto安装调试实录
- Type Script在Visual Studio 2013中的问题汇总(持续更新…)