当前位置:首页 > PHP

php实现csrf

2026-02-28 08:49:30PHP

PHP 实现 CSRF 防护的方法

CSRF(跨站请求伪造)是一种常见的网络攻击方式,攻击者利用用户已登录的身份,在用户不知情的情况下执行恶意操作。以下是几种在 PHP 中实现 CSRF 防护的方法:

使用 Token 验证

在表单或请求中嵌入一个随机生成的 Token,并在服务器端验证该 Token 是否匹配。

php实现csrf

// 生成 Token 并存储到 Session
session_start();
if (empty($_SESSION['csrf_token'])) {
    $_SESSION['csrf_token'] = bin2hex(random_bytes(32));
}

// 在表单中嵌入 Token
echo '<input type="hidden" name="csrf_token" value="' . $_SESSION['csrf_token'] . '">';

// 验证 Token
if ($_SERVER['REQUEST_METHOD'] === 'POST') {
    if (!isset($_POST['csrf_token']) || $_POST['csrf_token'] !== $_SESSION['csrf_token']) {
        die('CSRF 验证失败');
    }
}

使用 SameSite Cookie 属性

设置 Cookie 的 SameSite 属性为 StrictLax,限制跨站请求携带 Cookie。

php实现csrf

session_set_cookie_params([
    'samesite' => 'Strict',
    'secure' => true,
    'httponly' => true
]);
session_start();

检查 Referer 头部

验证请求的来源是否合法,但此方法不完全可靠,因为 Referer 可能被篡改或缺失。

if ($_SERVER['REQUEST_METHOD'] === 'POST') {
    $referer = parse_url($_SERVER['HTTP_REFERER'], PHP_URL_HOST);
    $server = $_SERVER['HTTP_HOST'];
    if ($referer !== $server) {
        die('CSRF 验证失败');
    }
}

使用框架内置的 CSRF 防护

许多 PHP 框架(如 Laravel、Symfony)已内置 CSRF 防护功能。以 Laravel 为例:

// 表单中自动生成 Token
<form method="POST" action="/example">
    @csrf
    ...
</form>

// 中间件自动验证 Token

注意事项

  • Token 应具有足够的随机性和长度,避免被猜测。
  • Token 应存储在 Session 中,而非 Cookie,防止被窃取。
  • 对于敏感操作(如修改密码、支付等),应强制使用 CSRF 防护。
  • 定期更新 Token,尤其是用户登录或权限变更时。

标签: phpcsrf
分享给朋友:

相关文章

php实现分页

php实现分页

PHP实现分页的基本方法 使用LIMIT和OFFSET进行数据库查询分页。通过计算当前页码和每页显示数量,动态生成SQL语句。 $page = isset($_GET['page']) ? (int…

php 实现验证码

php 实现验证码

使用 PHP 生成验证码 验证码(CAPTCHA)用于防止自动化脚本提交表单,以下是几种常见的 PHP 实现方法。 使用 GD 库生成图片验证码 GD 库是 PHP 的图像处理扩展,可用于生成验证…

php实现聊天

php实现聊天

实现 PHP 聊天功能的方法 使用 WebSocket 和 PHP 实现实时聊天 WebSocket 是一种全双工通信协议,适合实现实时聊天功能。PHP 可以通过 Ratchet 库实现 WebS…

php实现的分页

php实现的分页

PHP 实现分页的方法 基本分页逻辑 分页的核心在于计算总页数、当前页码以及数据偏移量。假设每页显示 10 条数据: $current_page = isset($_GET['page']) ?…

php数组实现

php数组实现

PHP 数组的基本实现 PHP 数组是一种非常灵活的数据结构,可以存储多个值,并且支持多种类型的键(整数或字符串)。PHP 数组实际上是有序映射(ordered map),可以看作是列表(vector…

php 线程实现

php 线程实现

PHP 线程实现方法 PHP 本身是单线程语言,但可以通过扩展或库实现多线程功能。以下是几种常见的实现方式: 使用 pthreads 扩展 pthreads 是一个 PHP 扩展,允许在 PHP 中…