0

0

php怎样验证小程序请求签名_php校验签名安全流程【步骤】

蓮花仙者

蓮花仙者

发布时间:2026-01-28 10:50:04

|

181人浏览过

|

来源于php中文网

原创

小程序sign验签需服务端用相同参数、时间戳、随机串、密钥及hmac_sha256算法重新计算并hash_equals比对;须校验时间偏移≤300秒、参数字典序拼接、UTF-8编码一致、密钥不泄露。

php怎样验证小程序请求签名_php校验签名安全流程【步骤】

小程序 sign 字段怎么验?先看它从哪来

小程序端调用 wx.request 发起请求时,如果服务端要求签名验证,通常由前端按约定规则拼接参数 + 时间戳 + 随机串 + 密钥,再用 sha256hmac_sha256 生成 sign后端必须用完全一致的原始数据和算法重新计算比对,否则必失败。

常见错误现象:sign mismatchinvalid signature、验签通过但偶尔失败。

  • 前端传的 timestamp 必须和服务端 time() 对齐(建议允许 ≤ 300 秒偏移)
  • 所有参与签名的参数必须按字典序升序排列 key,再拼成 key1=value1&key2=value2 形式(空值也要参与,不能忽略)
  • 密钥 $secret 绝不能硬编码在前端,应仅存于服务端配置中
  • 若使用 hmac_sha256,PHP 必须用 hash_hmac('sha256', $data, $secret),不能用 sha256($data . $secret)

PHP 里用 hash_hmac 还是 sha256?看小程序 SDK 文档

微信官方未强制签名算法,实际项目中绝大多数用 hmac_sha256,因其抗碰撞性强且密钥不参与明文拼接。

  • 小程序侧若用 crypto.createHmac('sha256', secret).update(data).digest('hex'),PHP 端必须对应 hash_hmac('sha256', $data, $secret, true)bin2hex()
  • 若小程序用 sha256(data + secret)(不推荐),PHP 得写 hash('sha256', $data . $secret),但这种易受长度扩展攻击
  • 注意:hash_hmac 第四个参数为 true 时返回二进制,false 返回十六进制字符串;前后端必须一致

示例片段:

立即学习PHP免费学习笔记(深入)”;

Figma
Figma

Figma 是一款基于云端的 UI 设计工具,可以在线进行产品原型、设计、评审、交付等工作。

下载
$raw = http_build_query($params, '', '&', PHP_QUERY_RFC3986);
$expectedSign = hash_hmac('sha256', $raw, $secret, true);
$expectedSign = bin2hex($expectedSign);
if (!hash_equals($expectedSign, $_POST['sign'])) {
    die('invalid signature');
}

验签前必须做这三件事:参数过滤、时间校验、字符标准化

签名本身只是最后一步,前面任一环节出错都会导致验签失败或安全漏洞。

  • 所有参与签名的参数(如 openidscenetimestamp)必须从 $_GET$_POST 显式取出,不能直接用 $_REQUEST
  • 检查 timestamp 是否在服务端当前时间 ±300 秒内,超时直接拒绝(防重放)
  • 统一编码:确保前后端都用 UTF-8 处理字符串,特别注意中文、emoji、URL 编码差异。PHP 中可用 urldecode()rawurldecode(),取决于前端如何编码(微信基础库默认用 encodeURIComponent,对应 PHP 的 rawurldecode

为什么 hash_equals 不能换成 ===

=== 比较签名会引发时序攻击风险——攻击者可通过响应时间差异逐步推断出正确签名。

  • hash_equals($expected, $input) 是 PHP 内置的恒定时间比较函数,无论输入是否相等,执行时间基本一致
  • 它要求两个参数都为字符串,且长度不同会直接返回 false,所以务必确保 $input 是合法 hex 字符串(可先用 ctype_xdigit() 判断)
  • 如果小程序传的 sign 是 base64 而非 hex,PHP 端得先 base64_decode(),再用 hash_equals 比较二进制结果(此时第一个参数也得是二进制)

真正容易被忽略的是:签名原文的构造顺序和编码方式,往往前端调试用 console.log 打印的是“看起来一样”的字符串,但实际多了一个空格、换行、不可见 Unicode 字符,或 URL 编码层级不一致 —— 这类问题只能靠服务端打日志对比原始字节才能定位。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

298

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1500

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

623

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

613

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

588

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

171

2025.07.29

c++字符串相关教程
c++字符串相关教程

本专题整合了c++字符串相关教程,阅读专题下面的文章了解更多详细内容。

83

2025.08.07

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

84

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
ECMAScript6 / ES6---十天技能课堂
ECMAScript6 / ES6---十天技能课堂

共25课时 | 2万人学习

进程与SOCKET
进程与SOCKET

共6课时 | 0.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号