hash_hmac函数讲解

在这里插入图片描述

hash_hmac函数的概述

PHP中的hash_hmac函数是一种基于加密哈希算法的函数,用于计算消息的哈希值。它返回一个哈希值字符串,并且可以用于验证消息的完整性和认证。

哈希是一种将任意长度的消息映射到固定长度的值的算法。哈希函数可以将任意大小的数据转换为固定大小的唯一输出值,这个输出值通常称为哈希值或摘要。通常情况下,消息的任何更改都会导致在哈希值上产生不可预测的变化。这使得哈希值非常适合用于数据完整性和身份验证。

在hash_hmac函数中,使用一个密钥对消息进行哈希。密钥可以是任意长度,并且必须与使用相同密钥的任何其他用户共享。因此,hash_hmac函数可以用于生成消息身份验证代码,以便其他人可以验证消息是否来自同一源。

hash_hmac函数的语法

hash_hmac ( string $algo , string $data , string $key [, bool $raw_output = FALSE ] ) : string

参数说明:
algo:使用的哈希算法,例如“md5”、“sha256”等。
data:要哈希的消息。
key:密钥(字符串)用于对消息进行哈希。
raw_output:如果设置为TRUE,则返回原始二进制数据。否则,默认以十六进制字符串格式输出。

实例演示

// 使用SHA256算法进行哈希,并且不输出原始二进制数据
$message = "Hello world";
$hash = hash_hmac("sha256", $message, "mysecretkey");
echo $hash;
//输出结果b1cd5d99bd0c85f3a2f5d0127d4bca7aeeedab1312e9f461feeeb4a773bc68f4

在本示例中,我们对"Hello world"这个消息使用了SHA-256哈希算法进行哈希。输出结果为长度为64的十六进制字符串。

对消息进行哈希并输出原始数据

// 使用HMAC-SHA1算法进行哈希,并输出原始二进制数据
$message = "Hello world";
$hash = hash_hmac("sha1", $message, "mysecretkey", true);
echo $hash;
//输出结果:
7b39d5ec177927c552f6405a9b79719e7d483b15

在本示例中,我们对"Hello world"这个消息使用了HMAC-SHA1哈希算法进行哈希,并使用了true参数输出了原始的二进制数据。

区分使用和不使用密钥进行哈希的区别

下面的示例演示了仅使用哈希算法和使用密钥进行哈希之间的差异:

// 仅对消息使用哈希算法
$message = "Hello world";
$hash1 = hash("sha256", $message);
echo "Hash without key: " . $hash1 . "<br>";// 使用HMAC-SHA256算法和密钥哈希消息
$message = "Hello world";
$hash2 = hash_hmac("sha256", $message, "mysecretkey");
echo "Hash with key: " . $hash2;
//输出结果
Hash without key: 916f0cebf8a4c8c09a4014c0d9fc1850bfe14f94c9315d4f09eea51f11d5263
Hash with key: b1cd5d99bd0c85f3a2f5d0127d4bca7aeeedab1312e9f461feeeb4a773bc68f4

在本示例中,我们在没有密钥的情况下使用了SHA256算法对"Hello world"这个消息进行哈希,并使用了相同的算法和密钥对同一消息进行了哈希。注意两者之间的差异,即使消息完全相同。

总结

在PHP中,hash_hmac函数提供了一种简单但强大的方法来生成哈希值,并可用于验证消息的完整性和身份认证。通过指定正确的哈希算法和密钥,您可以使用此函数生成高度安全的哈希值,并在各种情况下使用它们。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/236101.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Windows系列:Windows的13个版本以及 Windows Server详解(配置)

Windows的13个版本以及 Windows Server详解&#xff08;配置&#xff09; 一. Windows的13个版本的区别&#xff0c;企业版、教育版、专业版、工作站版、SE版的主要区别家庭版专业版教育版企业版Servers版 二. Windows Server VS Windows&#xff0c;两者有啥区别&#xff1f;什…

计算机服务器中了_locked勒索病毒如何处理,_locked勒索病毒解密数据恢复

网络技术的不断发展&#xff0c;给企业的生产生活提供了极大便利&#xff0c;越来越多的企业走向数字化办公时代&#xff0c;但网络的发展也为网络安全埋下隐患&#xff0c;网络安全威胁不断增加。近期&#xff0c;云天数据恢复中心陆续接到很多企业的求助&#xff0c;企业的计…

基于Python Flask 的全流程全栈项目自己的实战心得

我基于Python Flask框架开发全流程全栈项目的实战经验和心得。我将介绍整个项目的架构设计、前后端交互、数据库管理以及部署等方面&#xff0c;并提供具体的代码示例。通过这个实例项目&#xff0c;你将学习到如何使用Flask构建一个完整的Web应用&#xff0c;并了解一些常见的…

如何让嵌入式开发板使用主机的网络

配置网络 1.开发板配置 将开发板和主机用网线连接 安装 net-tools&#xff0c;使用 ifconfig 命令 或者使用 ip 命令 su root ip a 发现一个 eth0的网口 ip link set xxx up 有多个网口时可以用该命令启用某一个网口 vim /etc/netplan/00-installer-config.yaml写入以下…

人工智能 - 目标检测:发展历史、技术全解与实战

目录 一、早期方法&#xff1a;滑动窗口和特征提取滑动窗口机制工作原理 特征提取方法HOG&#xff08;Histogram of Oriented Gradients&#xff09;SIFT&#xff08;Scale-Invariant Feature Transform&#xff09; 二、深度学习的兴起&#xff1a;CNN在目标检测中的应用CNN的…

C++ 学习之匿名名字空间的使用细节

匿名命名空间&#xff08;anonymous namespace&#xff09;是C中的一种特殊命名空间&#xff0c;它没有显式的名称。匿名命名空间可以用来定义仅在当前文件中可见的全局变量、函数和类。 由于没有名字&#xff0c;所以相当于直接引入&#xff0c;但是没有引入定义 如果发生冲…

堆栈_有效括号

题比较特殊&#xff0c;主要在于它的所有要输入&#xff0c;都是左括号开头&#xff0c;没有右括号开头的&#xff0c;比如"] ["&#xff0c;这种是不算为括号的&#xff0c;由于必然是对称的&#xff0c;若能符合&#xff0c;因而直接在遇到右括号时&#xff0c;检查…

06、基于内容的过滤算法Tensorflow实现

06、基于内容的过滤算法Tensorflow实现 开始学习机器学习啦&#xff0c;已经把吴恩达的课全部刷完了&#xff0c;现在开始熟悉一下复现代码。对这个手写数字实部比较感兴趣&#xff0c;作为入门的素材非常合适。 05、基于梯度下降的协同过滤算法中已经介绍了协同过滤算法的基…

什么是AI PC:人工智能电脑?

大家好啊&#xff0c;我是董董灿。 今天在一个群聊里&#xff0c;聊到了关于 AI PC (人工智能电脑)的话题。 之前看到过关于 AI PC 的新闻&#xff0c;说的是联想集团董事长兼CEO杨元庆在一次演讲中提到了 AI PC 的概念&#xff0c;并且绘声绘色的描绘了AI PC 的发展前景。 下…

【滑动窗口】无重复字符的最长字串

无重复字符的最长字串 文章目录 无重复字符的最长字串题目描述算法思路思路一思路二 代码编写暴力解法滑动窗口 3. 无重复字符的最长子串 - 力扣&#xff08;LeetCode&#xff09; 题目描述 给定一个字符串 s &#xff0c;请你找出其中不含有重复字符的 最长子串 的长度。 示…

mysql中字符串截取与拆分

按分隔符把字符串拆成多行 引言截取字符串一、left(str,length)二、right(str,length)三、截取特定长度的字符串四、按分隔符截取 分割字符串一、分割成多列二、分割成多行 总结 引言 截取和拆分字符串在编程生涯中是普遍存在的&#xff0c;在sql中也不例外&#xff0c;下面就…

Springboot-注册注解【springboot常用注解】

1.组件注册 1.1 使用的注解 Configuration:普通配置类,替代以前的配置文件,配置类本身也是容器的组件|SpringBootConfiguration:Springboot配置类,与Configuration功能一样|Bean:替代以前的Bean标签,如果没有在Bean标签内定义名字,则默认组件的名字为方法名,可以直接修改注解…