Java中一种计算Hash值的算法——SHA-256
SHA-256:一种哈希函数
对于任意长度的消息,SHA-256都会产生一个256bit长的哈希值,称作消息摘要。这个摘要相当于是个长度为32个字节的数组,通常用一个长度为64的十六进制字符串来表示。
String password = "123";
StringBuilder sb = new StringBuilder();
MessageDigest object = MessageDigest.getInstance("SHA-256");
byte[] encrypted = object.digest(password.getBytes("UTF-8"));
for (byte b : encrypted) {
sb.append(String.format("%02x", b));
}
- 返回实现了具体算法的对象,这里指”SHA-256″
MessageDigest object = MessageDigest.getInstance("SHA-256");
- 返回哈希值的字节数组
byte[] encrypted = object.digest(password.getBytes("UTF-8"));
获取哈希值的字节数组,需要先传入一个字节数password.getBytes("UTF-8")。
- 最后以十六进制的字符串表示该哈希值
(String.format("%02x", b)
注意:
使用哈希函数处理密码不能算作加密,因为不同的密码的hash值可能会相同,也就是可能产生碰撞(因为存在hash冲突的缘故),即也只能保证单方向转换,不能保证将hash后的值转换为原密码。
参考博客:SHA-256详解
原文作者:长不大的大灰狼
原文地址: https://blog.csdn.net/glpghz/article/details/105650385
本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
原文地址: https://blog.csdn.net/glpghz/article/details/105650385
本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
相关文章