在 PHP 中,处理 CSRF(跨站请求伪造)令牌的存储可以通过以下步骤进行:
bin2hex(random_bytes(32))
来实现。$csrf_token = bin2hex(random_bytes(32));
$_SESSION
超全局变量来实现这一点。确保在使用会话之前启动了会话。session_start();
$_SESSION['csrf_token'] = $csrf_token;
<form action="submit.php" method="post">
<!-- 其他表单字段 -->
<input type="hidden" name="csrf_token" value="<?php echo $_SESSION['csrf_token']; ?>">
<input type="submit" value="提交">
</form>
session_start();
if (isset($_POST['csrf_token']) && hash_equals($_SESSION['csrf_token'], $_POST['csrf_token'])) {
// 验证成功,处理表单数据
} else {
// 验证失败,显示错误消息或处理错误
echo "Invalid CSRF token.";
}
通过以上步骤,你可以在 PHP 应用程序中有效地处理 CSRF 令牌的存储和验证。这将有助于保护你的应用程序免受跨站请求伪造攻击。