哈希函数非常有用,并且几乎出现在所有信息安全应用程序中。
哈希函数是一种数学函数,可将数字输入值转换为另一个压缩数字值。哈希函数的输入为任意长度,但输出始终为固定长度。
哈希函数返回的值称为消息摘要或简称为哈希值。下图说明了哈希函数。
Java提供了一个名为 MessageDigest 的类,该类属于包java.security。此类支持SHA-1,SHA 256,MD5等算法以将任意长度的消息转换为消息摘要。
要将给定消息转换为消息摘要,请遵循以下步骤-
MessageDigest类提供了 getInstance()的方法。此方法接受一个String变量,该变量指定要使用的算法名称,并返回指定算法的MessageDigest对象 。
使用 getInstance()方法创建MessageDigest 对象 ,如下所示。
MessageDigest md=MessageDigest.getInstance("SHA-256");
创建消息摘要对象后,您需要将需要加密的消息/数据(message/data)传递给它。您可以使用 MessageDigest 类的 update()方法来执行此操作,该方法接受表示消息的字节数组,并将其添加/传递(adds/passes)给上面创建的MessageDigest对象 。
md.update(msg.getBytes());
您可以使用MessageDigest类的 digest()方法生成消息摘要,此方法将计算当前对象上的哈希函数,并以字节数组的形式返回消息摘要。
使用摘要方法生成消息摘要。
byte[] digest=md.digest();
以下是一个从文件读取数据并生成消息摘要并进行打印的示例。
import java.security.MessageDigest; import java.util.Scanner; public class MessageDigestExample { public static void main(String args[]) throws Exception{ //从用户那里读取数据 Scanner sc = new Scanner(System.in); System.out.println("Enter the message"); String message = sc.nextLine(); //创建 MessageDigest 对象 MessageDigest md = MessageDigest.getInstance("SHA-256"); //将数据传递给创建的 MessageDigest 对象 md.update(message.getBytes()); //计算消息摘要 byte[] digest = md.digest(); System.out.println(digest); //将字节数组转换为 HexString 格式 StringBuffer hexString = new StringBuffer(); for (int i = 0;i<digest.length;i++) { hexString.append(Integer.toHexString(0xFF & digest[i])); } System.out.println("Hex format : " + hexString.toString()); } }
上面的程序生成以下输出-
Enter the message Hello how are you [B@55f96302 Hex format: 2953d33828c395aebe8225236ba4e23fa75e6f13bd881b9056a3295cbd64d3
祝学习愉快!(内容编辑有误?请选中要编辑内容 -> 右键 -> 修改 -> 提交!)