Java中一种计算Hash值的算法——SHA-256

2022-06-21 00:00:00 java 算法 计算

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));
    }
  1. 返回实现了具体算法的对象,这里指”SHA-256″
MessageDigest object = MessageDigest.getInstance("SHA-256");
  1. 返回哈希值的字节数组
byte[] encrypted = object.digest(password.getBytes("UTF-8"));

获取哈希值的字节数组,需要先传入一个字节数password.getBytes("UTF-8")。

  1. 最后以十六进制的字符串表示该哈希值
(String.format("%02x", b)

注意:
使用哈希函数处理密码不能算作加密,因为不同的密码的hash值可能会相同,也就是可能产生碰撞(因为存在hash冲突的缘故),即也只能保证单方向转换,不能保证将hash后的值转换为原密码。
《Java中一种计算Hash值的算法——SHA-256》
参考博客:SHA-256详解

    原文作者:长不大的大灰狼
    原文地址: https://blog.csdn.net/glpghz/article/details/105650385
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。

相关文章