Maison > développement back-end > tutoriel php > Comment protéger les fonctions PHP des attaques CSRF ?

Comment protéger les fonctions PHP des attaques CSRF ?

WBOY
Libérer: 2024-05-01 14:39:01
original
389 Les gens l'ont consulté

摘要:PHP 函数中的 CSRF 攻击可通过使用令牌防御:生成唯一令牌并存储在会话或 cookie 中。将令牌包含在受保护表单中作为隐藏字段。处理表单提交时,验证令牌是否与存储的令牌匹配。不匹配则拒绝请求。

如何防止 PHP 函数受到 CSRF 攻击?

如何防御 PHP 函数中的 CSRF 攻击

跨站点请求伪造 (CSRF) 是一种恶意技术,它允许攻击者通过受害者的浏览器发送欺骗性请求。对于 PHP 应用程序来说,这可能会使攻击者利用某些函数执行未经授权的操作。

实战案例:

假设您有一个 PHP 应用程序,其中包含一个允许用户更改密码的函数 change_password。该函数使用以下代码:

<?php
if (isset($_POST['password'])) {
  $password = $_POST['password'];

  // 更新数据库中的密码...
}
?>
Copier après la connexion

此代码容易受到 CSRF 攻击,因为攻击者可以向受害者的浏览器发送一个 POST 请求,其中包含他们希望用于受害者密码的 password 参数。这种攻击可以通过欺骗性的电子邮件、恶意网站或其他方法来实现。

防御措施:

为了防御 CSRF 攻击,需要实现机制来验证请求的真实性。一种常用的方法是使用令牌。

  1. 生成令牌:

创建一个唯一的且难以猜测的令牌,并将其存储在会话或 cookie 中。

<?php
session_start();

// 生成令牌并将其存储在会话中
$_SESSION['csrf_token'] = bin2hex(random_bytes(32));
?>
Copier après la connexion
  1. 将令牌包含在表单中:

在要保护的表单中,将令牌作为隐藏字段包含。

<form action="change_password.php" method="post">
  <input type="hidden" name="csrf_token" value="<?php echo $_SESSION['csrf_token']; ?>" />
  <!-- 其他表单字段 -->
</form>
Copier après la connexion
  1. 验证令牌:

在处理表单提交时,验证令牌是否与会话或 cookie 中存储的令牌匹配。如果不匹配,则拒绝请求。

<?php
if (!isset($_POST['csrf_token']) || $_POST['csrf_token'] !== $_SESSION['csrf_token']) {
  // 令牌验证失败,拒绝请求
  exit('Invalid request');
}
?>
Copier après la connexion

通过实施这些防御措施,您可以降低 PHP 应用程序遭受 CSRF 攻击的风险。

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal