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

本文详细介绍了SHA-256哈希函数的工作原理及应用,演示了如何使用Java实现SHA-256对字符串进行哈希处理,包括获取哈希值的字节数组,并将其转换为十六进制字符串形式。强调了哈希函数在密码学中的作用,以及其不可逆性和可能存在的哈希碰撞问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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后的值转换为原密码。
1
参考博客:SHA-256详解

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值