首页 游戏 软件 资讯 排行榜 专题
首页
编程语言
PHP怎么防止CSRF跨站请求伪造_PHP CSRF令牌验证技巧【技巧】

PHP怎么防止CSRF跨站请求伪造_PHP CSRF令牌验证技巧【技巧】

热心网友
14
转载
2026-05-06

PHP防CSRF的核心是令牌必须不可预测、不可复用、绑定用户上下文;需用random_bytes()生成强随机令牌,绑定IP/时间戳,验证时检查时效性、绑定信息并立即销毁,否则防护失效。

PHP怎么防止CSRF跨站请求伪造_PHP CSRF令牌验证技巧【技巧】

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

在PHP开发中,防止CSRF攻击,远不止“在表单里加个隐藏字段”那么简单。真正的核心在于,你生成的令牌必须做到三点:不可预测、不可复用、并且与当前用户上下文紧密绑定。否则,即便$_SESSION['csrf_token']$_POST['token']对上了,防护也可能形同虚设。

为什么简单session+表单hidden就可能失效

很多项目的做法看起来很标准:用户登录后生成一个随机字符串存入$_SESSION['csrf_token'],然后把这个值塞进表单的里。流程没错,但仔细推敲,这种方案至少存在三个致命缺口:

  • 令牌未与用户IP或User-Agent绑定。这意味着,攻击者只要能在同一浏览器会话中诱导用户点击恶意链接,就可能复用这个令牌发起请求。
  • 令牌没有设置过期时间。一个长期有效的令牌,本质上就是一个可被重放攻击的长期通行证。
  • 验证通过后,令牌未被立即销毁或轮换。一旦令牌被窃取,攻击者就能反复使用,直到会话结束。

bin2hex(random_bytes())生成强令牌,别用md5(time().rand())

令牌的生成质量是防护的第一道门槛。像md5()uniqid()mt_rand()这类函数,要么输出可预测,要么熵值不足,很容易被暴力破解或推测。在PHP 7及以上版本,务必使用加密安全的随机数生成器:

// ✅ 正确做法:生成16字节强随机数,并转换为32位十六进制字符串
$token = bin2hex(random_bytes(16));

// ❌ 错误示范:基于时间戳和弱随机数的组合极易被推测
$token = md5(time() . rand(1000, 9999));

令牌生成后,建议立刻存入session,并附带时间戳及可选的绑定信息,为后续验证打下基础:

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

$_SESSION['csrf_token'] = [
    'value' => $token,
    'created_at' => time(), // 记录生成时间
    'ip_hash' => hash('sha256', $_SERVER['REMOTE_ADDR'] ?? ''), // 可选:绑定IP哈希
];

验证时必须检查时效、绑定和一次性,三者缺一不可

收到$_POST['token']后,验证逻辑绝不能只是简单的字符串比对。必须同步执行以下几层检查:

  • 确认$_SESSION['csrf_token']['value']存在且非空。
  • 检查令牌是否在有效期内,例如:time() - $_SESSION['csrf_token']['created_at'] <= 3600(设为1小时过期)。
  • 可选但强烈推荐:校验IP绑定是否一致,使用hash_equals进行安全比较。
  • 最关键的一步——验证通过后,**立即销毁$_SESSION['csrf_token']**,强制实现一次性使用。

如果应用需要支持多标签页并行操作(比如用户同时打开两个编辑页面),可以考虑采用“令牌池”策略:每次生成新令牌时,在session中保留最近3个有效的令牌;验证时遍历池子进行匹配,并清除匹配到的令牌。

前端表单怎么安全传token?别只靠hidden input

单纯依赖在复杂的AJAX应用场景下容易遗漏。更健壮的前后端协作方案如下:

  • 所有可能修改数据的表单(POST/PUT/DELETE),都包含隐藏的CSRF令牌字段。
  • 为支持AJAX,可以在页面中插入一个meta标签来存放令牌,避免Ja vaScript直接暴露session变量:
  • 前端Ja vaScript通过document.querySelector('meta[name="csrf-token"]').getAttribute('content')获取令牌,并将其设置为所有非GET请求的X-CSRF-TOKEN请求头。
  • 后端通过统一的中间件或拦截函数,对所有非GET请求进行校验,优先检查X-CSRF-TOKEN请求头,再回退检查POST数据体。

需要注意的是,采用请求头方式时,必须确保服务器的CORS(跨域资源共享)配置允许该自定义头,即在Access-Control-Allow-Headers中包含X-CSRF-TOKEN,否则预检请求会失败。

回顾起来,CSRF防御最常被绕开的点,往往不是令牌生成算法有多复杂,而是验证后忘了清理、没有设置过期时间,或者错误地将令牌写成了全局常量——这些疏忽,足以让整套防护体系功亏一篑。

来源:https://www.php.cn/faq/2313027.html
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

相关攻略

如何在 PHP 中高效获取多页 TIFF 图像的总页数(无需加载整个文件)
编程语言
如何在 PHP 中高效获取多页 TIFF 图像的总页数(无需加载整个文件)

本文详解如何利用 php-vips 替代传统的 imagemagick 方案,在毫秒级别快速获取超大 JPEG 压缩 TIFF 文件(例如 1 5GB 2600 页)的总页数,彻底规避 imagick 因加载全部数据而引发的严重性能延迟问题。 在 PHP 开发中,处理大型多页 TIFF 文件(尤其是

热心网友
05.05
PHP函数如何识别硬件RAID控制器_PHP区分软硬RAID配置【教程】
编程语言
PHP函数如何识别硬件RAID控制器_PHP区分软硬RAID配置【教程】

PHP函数如何识别硬件RAID控制器_PHP区分软硬RAID配置【教程】 PHP 无法直接识别硬件 RAID 控制器 这里有个核心概念需要先厘清:PHP作为运行在用户态的脚本语言,本身并没有内核级别的权限。这意味着,它既无法直接访问SCSI或SAS控制器的底层寄存器,也读不了PCI设备的ID信息,更

热心网友
05.05
phpopenssl扩展怎么配置_https与加密功能【教程】
编程语言
phpopenssl扩展怎么配置_https与加密功能【教程】

PHP的openssl扩展怎么配置_https与加密功能【教程】 PHP的openssl扩展需同时满足扩展已加载、密钥可用、证书链可信三条件;否则HTTPS请求、加密函数等均会失败,须逐项验证配置、CA路径、IV 密钥长度及PEM格式。 将PHP的openssl扩展视为一个“配置即用”的普通模块,往

热心网友
05.05
PHP如何检测客户端是否支持Cookie_PHP检测客户端是否支持Cookie方法【兼容】
编程语言
PHP如何检测客户端是否支持Cookie_PHP检测客户端是否支持Cookie方法【兼容】

PHP如何检测客户端是否支持Cookie:几种兼容性良好的实战方法 在Web开发中,依赖Cookie的功能(比如用户登录状态保持)能否正常运行,有时得打个问号。毕竟,用户可能手动禁用了它,或者某些特殊环境本身就有限制。那么,如何在服务端稳稳当当地判断客户端是否真的支持Cookie呢?今天就来聊聊几种

热心网友
05.05
如何通过命令行执行 PHAR 归档中的 PHP 文件
编程语言
如何通过命令行执行 PHAR 归档中的 PHP 文件

如何通过命令行执行 PHAR 归档中的 PHP 文件 本文详细解析在 RHEL 7 系统中,如何正确配置 PHAR 归档以同时支持 Web 访问与命令行独立执行(例如用于定时任务),重点解决执行 `php phar phar path to script php` 时出现“Could not ope

热心网友
05.05

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

Go 中错误处理的惯用法:如何写出简洁、健壮且符合 Go 风格的错误处理代码
编程语言
Go 中错误处理的惯用法:如何写出简洁、健壮且符合 Go 风格的错误处理代码

Go 语言错误处理最佳实践:编写简洁、健壮且符合 Go 风格的代码指南 Go 语言采用多返回值(值 + error)实现显式错误处理,其标准做法是在每次函数调用后立即检查 err 是否为 nil;虽然忽略错误在语法上可行,但这违背了 Go 的设计哲学,极易导致隐蔽的 panic 或难以追踪的逻辑错误

热心网友
05.06
Python编写Flask接口如何限制请求频率_使用Flask-Limiter防止接口滥用
编程语言
Python编写Flask接口如何限制请求频率_使用Flask-Limiter防止接口滥用

Python Flask接口请求频率限制实战:Flask-Limiter防刷指南 Flask-Limiter 初始化配置详解:避免应用上下文错误 应用上下文配置不当,是开发者初次集成 Flask-Limiter 时最常见的错误。核心症结在于,限流器必须在 Flask 应用实例完全初始化且应用上下文就

热心网友
05.06
2026年涨100倍的币会是哪些?可能有哪些
web3.0
2026年涨100倍的币会是哪些?可能有哪些

2026年可能涨100倍的币会是哪些? 市场总是在寻找下一个爆发点。如果说2026年的加密货币市场存在百倍增长的可能,那么机会大概率会落在那些手握硬核技术、生态正在快速扩张、并能精准切入新兴应用场景的项目上。纵观行业趋势与数据,有五个名字反复被提及:Sui、Filecoin、Cosmos、Kaspa

热心网友
05.06
Python程序PyTorch显存泄漏怎么办_利用torch.cuda.empty_cache清理
编程语言
Python程序PyTorch显存泄漏怎么办_利用torch.cuda.empty_cache清理

torch cuda empty_cache() 仅释放未被张量引用的缓存显存,不回收仍被变量或模型持有的显存;需配合 del、zero_grad() 和 no_grad() 才能有效释放。 为什么 torch cuda empty_cache() 经常不起作用? 简单来说,这个函数的作用范围非常有

热心网友
05.06
如何在 WooCommerce 中隐藏无缩略图的产品
编程语言
如何在 WooCommerce 中隐藏无缩略图的产品

如何在 WooCommerce 中隐藏无缩略图的产品 本文详细讲解如何通过自定义代码过滤 WooCommerce 商品查询,自动排除未设置特色图像(产品主图)的商品,确保店铺前台仅展示带有有效产品图片的商品条目,提升页面美观度与专业感。 你是否希望自己的 WooCommerce 在线商店前台只呈现那

热心网友
05.06