0

0

PHP加密如何防重放攻击_时间戳随机数校验请求有效【方法】

星夢妙者

星夢妙者

发布时间:2026-02-07 15:33:09

|

318人浏览过

|

来源于php中文网

原创

PHP防重放必须签名而非仅校验timestamp和nonce:攻击者可重放合法请求,需用hash_hmac('sha256', $data_string, $secret_key)签名,覆盖timestamp、nonce、业务参数及密钥,并严格保证参数字典序排序、urlencode、Redis SETNX原子存nonce、时间窗口±5分钟容错。

php加密如何防重放攻击_时间戳随机数校验请求有效【方法】

PHP中时间戳+随机数校验为何不能单独防重放

单纯在请求里传 timestampnonce(随机数),服务端只做“是否已用过该 nonce”或“timestamp 是否超5分钟”,是无效的。攻击者截获一次合法请求后,可立刻重放——只要时间仍在窗口内、nonce 未被服务端全局去重(比如没存 Redis 或 DB),校验就形同虚设。

必须配合签名(sign)且签名覆盖时间戳与随机数

签名才是防重放的核心防线:它把 timestampnonce、业务参数、密钥一起哈希,确保任何字段篡改或重放都会导致 sign 不匹配。常见错误是签名漏掉 timestampnonce,或排序不一致导致客户端和服务端算出不同结果。

  • 推荐用 hash_hmac('sha256', $data_string, $secret_key),比 md5() 或裸 sha1() 更安全
  • $data_string 必须固定格式:所有参数按 key 字典序排序,拼成 k1=v1&k2=v2×tamp=1717023456&nonce=abc123,且 value 要 urlencode()
  • 服务端收到请求后,先校验 timestamp 是否在 ±5 分钟内,再查 nonce 是否已存在(建议用 Redis SETNX nonce 1 EX 300),最后才验签

Redis 存 nonce 的几个关键细节

用 Redis 记录已用 nonce 是最常用做法,但容易忽略过期策略和原子性问题。

  • 不能用 SET nonce 1 + 单独 EXPIRE:中间可能被并发请求绕过。必须用 SET nonce 1 EX 300 NXNX 保证仅当 key 不存在时才设)
  • key 过期时间(EX 300)应略大于时间戳允许偏差(如 5 分钟),避免因服务器时间差导致误判
  • 如果请求量极大,可考虑用 HASH 分桶(如按 nonce 前两位分 100 个 key),避免单 key 热点

客户端时间不准怎么办?服务端要容忍一定偏差

手机 App 或浏览器本地时间可能快慢几分钟,硬性要求客户端和服务端时间完全同步不现实。服务端校验 timestamp 时,必须留出缓冲窗口。

闪电说
闪电说

AI语音输入法

下载

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

  • 建议检查 abs($server_time - $request_timestamp) (5 分钟),而不是只判断 $request_timestamp > $server_time - 300
  • 不要依赖客户端传的时区或格式,统一按 Unix timestamp(整数秒)处理,拒绝带毫秒、带时区或非数字的 timestamp
  • 如果业务对时效性极高(如支付确认),可额外增加 seq(单调递增序列号)并维护用户级最新 seq,但会提高服务端状态管理成本

真正难的不是生成 sign 或存 nonce,而是所有环节——参数排序规则、urlencode 行为、Redis 命令原子性、时间窗口定义——必须客户端和服务端严丝合缝。一个空格、一个未编码的特殊字符、一次漏掉 NX,都可能导致防线失效。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
常用的数据库软件
常用的数据库软件

常用的数据库软件有MySQL、Oracle、SQL Server、PostgreSQL、MongoDB、Redis、Cassandra、Hadoop、Spark和Amazon DynamoDB。更多关于数据库软件的内容详情请看本专题下面的文章。php中文网欢迎大家前来学习。

986

2023.11.02

内存数据库有哪些
内存数据库有哪些

内存数据库有Redis、Memcached、Apache Ignite、VoltDB、TimesTen、H2 Database、Aerospike、Oracle TimesTen In-Memory Database、SAP HANA和ache Cassandra。更多关于内存数据库相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

650

2023.11.14

mongodb和redis哪个读取速度快
mongodb和redis哪个读取速度快

redis 的读取速度比 mongodb 更快。原因包括:1. redis 使用简单的键值存储,而 mongodb 存储 json 格式的数据,需要解析和反序列化。2. redis 使用哈希表快速查找数据,而 mongodb 使用 b-tree 索引。因此,redis 在需要高性能读取操作的应用程序中是一个更好的选择。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

493

2024.04.02

redis怎么做缓存服务器
redis怎么做缓存服务器

redis 作为缓存服务器的答案:redis 是一款开源、高性能、分布式的键值存储,可作为缓存服务器使用。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

404

2024.04.07

redis怎么解决数据一致性
redis怎么解决数据一致性

redis 提供了两种一致性模型,以维护副本数据一致性:强一致性 (sync) 确保写操作仅在复制到所有从节点后才完成;最终一致性 (async) 则在主节点上写操作后认为已完成,牺牲一致性换取性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

399

2024.04.07

mysql和redis怎么保证双写一致性
mysql和redis怎么保证双写一致性

确保 mysql 和 redis 双写一致性的技术包括:1、事务性更新:同时更新 mysql 和 redis,保证一致性;2、主从复制:mysql 主服务器更改同步到 redis 从服务器;3、基于事件的更新:mysql 记录更改并发送到 redis等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

460

2024.04.07

redis缓存一般存些什么数据
redis缓存一般存些什么数据

redis缓存中存储的数据类型包括:字符串、哈希、列表、集合、有序集合、位图、地理空间数据和hyperloglog。这些数据类型适用于存储各种数据,从简单信息到复杂对象和地理位置。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

413

2024.04.07

redis的8种数据类型有哪些
redis的8种数据类型有哪些

redis 提供 8 种数据类型:字符串(文本、数字、二进制)、哈希(键值对)、列表(有序集合)、集合(无序唯一元素)、有序集合(按分数排序)、地理空间(地理位置)、hyperloglog(估计大数据基数)和位图(位序列存储)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

437

2024.04.07

Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

2

2026.02.06

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 11.2万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.2万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

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

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