0

0

如何防止通过浏览器控制台伪造 AJAX 请求提交恶意数据

花韻仙語

花韻仙語

发布时间:2026-03-02 22:11:01

|

504人浏览过

|

来源于php中文网

原创

如何防止通过浏览器控制台伪造 AJAX 请求提交恶意数据

本文介绍在无框架的纯 JavaScript + PHP 开发中,如何有效防御用户通过浏览器开发者工具直接调用 $.post() 篡改并提交虚假分数等关键业务数据,核心方案是将“客户端提交结果”改为“客户端提交行为过程”,由服务端校验逻辑并生成可信结果。

本文介绍在无框架的纯 javascript + php 开发中,如何有效防御用户通过浏览器开发者工具直接调用 `$.post()` 篡改并提交虚假分数等关键业务数据,核心方案是将“客户端提交结果”改为“客户端提交行为过程”,由服务端校验逻辑并生成可信结果。

在前端单机类游戏(如记忆配对游戏)中,仅靠前端计算并提交最终分数(如 score: 11111111)存在根本性安全缺陷:所有客户端数据均可被绕过、篡改或重放。即使你添加了 CSRF Token、请求头校验或前端防调试逻辑,只要接口接收 {"player_name": "Cheater", "score": 999999} 并直接入库,攻击者就能在 DevTools 中一行 $.post(...) 完成作弊——这不是漏洞,而是设计误用。

✅ 正确思路:信任边界必须落在服务端
客户端只负责上报「可验证的行为过程」,服务端负责复现逻辑、校验合法性,并生成唯一可信结果。以记忆游戏为例:

  • ❌ 错误做法(当前):前端计算总分 → 直接提交 score
  • ✅ 正确做法:前端记录每一步操作(如翻牌顺序、配对时间、是否错误)→ 提交原始操作日志 → 后端按相同规则重算分数

? 实施示例(轻量级改造)

1. 前端:记录并提交可审计的操作序列

UXbot
UXbot

AI产品设计工具

下载
// 在游戏过程中累积操作(例如每次翻牌/配对)
const gameActions = [];

function recordAction(type, data) {
  gameActions.push({
    type,
    data,
    timestamp: Date.now()
  });
}

// 示例:用户成功配对一对卡片
recordAction('match', { card1: 'cat', card2: 'cat', duration: 1250 });

// 提交时发送完整操作流(而非最终分数)
$("#submitScore").on("click", function() {
  const playerName = $('#playerName').val().trim() || "Unknown";

  $.post("./backend/save_score.php", {
    player_name: playerName,
    actions: JSON.stringify(gameActions), // 传输原始行为,非结果
    game_id: "memory_v1" // 可选:标识游戏版本,便于后端兼容校验
  }, function(response) {
    if (response.success) {
      fetchHighScores();
      $("#submitScore").prop('disabled', true);
    } else {
      alert("提交失败:" + response.error);
    }
  });
});

2. 后端(save_score.php):严格校验 + 服务端计分

<?php
header('Content-Type: application/json');

// 简单基础防护(非替代逻辑校验)
if ($_SERVER['REQUEST_METHOD'] !== 'POST') {
    die(json_encode(['success' => false, 'error' => 'Method not allowed']));
}

$playerName = filter_var($_POST['player_name'] ?? '', FILTER_SANITIZE_STRING);
$actionsJson = $_POST['actions'] ?? '';

if (empty($playerName) || empty($actionsJson)) {
    die(json_encode(['success' => false, 'error' => 'Missing required fields']));
}

$actions = json_decode($actionsJson, true);
if (!is_array($actions) || count($actions) === 0) {
    die(json_encode(['success' => false, 'error' => 'Invalid actions format']));
}

// ✅ 关键:服务端重放游戏逻辑,计算可信分数
$totalScore = 0;
$matches = 0;
$errors = 0;

foreach ($actions as $act) {
    if ($act['type'] === 'match') {
        // 示例规则:匹配正确 +10 分,且需符合游戏逻辑(如不能重复匹配同一对)
        $matches++;
        $totalScore += 10;
    } elseif ($act['type'] === 'mismatch') {
        $errors++;
        $totalScore = max(0, $totalScore - 2); // 惩罚机制
    }
}

// 进阶建议:添加合理性检查(如操作数是否符合关卡设计、时间戳是否异常集中等)
if ($matches < 1 || $matches > 20) { // 假设本局最多10对,即20次匹配
    die(json_encode(['success' => false, 'error' => 'Suspicious action count']));
}

// 安全写入数据库(使用预处理防止SQL注入)
$pdo = new PDO('mysql:host=localhost;dbname=game', $user, $pass);
$stmt = $pdo->prepare("INSERT INTO scores (player_name, score, created_at) VALUES (?, ?, NOW())");
$stmt->execute([$playerName, $totalScore]);

echo json_encode(['success' => true, 'score' => $totalScore]);

⚠️ 重要注意事项

  • 永远不要信任 score、level、time 等结果型字段:它们必须由服务端基于可验证输入生成;
  • 操作日志需包含足够上下文:如卡片 ID、操作类型、时间戳、甚至哈希摘要(可选),便于后期审计;
  • 加入轻量反自动化策略(非必需但推荐):例如检测操作间隔是否过短(
  • CSRF Token 仍建议保留:虽不能阻止此场景作弊,但能防范跨站请求伪造,属于纵深防御一环;
  • 前端校验仅用于体验优化:如实时提示“配对成功”,但绝不作为可信依据。

总结来说,防御“控制台提交假分”的本质不是封锁 AJAX 调用,而是重构数据契约——让客户端成为“行为记录仪”,服务端成为“唯一裁判”。这套模式无需框架、不增加复杂度,却能从根本上关闭作弊通道,是轻量级 Web 游戏最务实的安全实践。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
ajax教程
ajax教程

php中文网为大家带来ajax教程合集,Ajax是一种用于创建快速动态网页的技术。通过在后台与服务器进行少量数据交换,Ajax可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。php中文网还为大家带来ajax的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

166

2023.06.14

ajax中文乱码解决方法
ajax中文乱码解决方法

ajax中文乱码解决方法有设置请求头部的字符编码、在服务器端设置响应头部的字符编码和使用encodeURIComponent对中文进行编码。本专题为大家提供ajax中文乱码相关的文章、下载、课程内容,供大家免费下载体验。

170

2023.08.31

ajax传递中文乱码怎么办
ajax传递中文乱码怎么办

ajax传递中文乱码的解决办法:1、设置统一的编码方式;2、服务器端编码;3、客户端解码;4、设置HTTP响应头;5、使用JSON格式。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

124

2023.11.15

ajax网站有哪些
ajax网站有哪些

使用ajax的网站有谷歌、维基百科、脸书、纽约时报、亚马逊、stackoverflow、twitter、hacker news、shopify和basecamp等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

251

2024.09.24

登录token无效
登录token无效

登录token无效解决方法:1、检查token的有效期限,如果token已经过期,需要重新获取一个新的token;2、检查token的签名,如果签名不正确,需要重新获取一个新的token;3、检查密钥的正确性,如果密钥不正确,需要重新获取一个新的token;4、使用HTTPS协议传输token,建议使用HTTPS协议进行传输 ;5、使用双因素认证,双因素认证可以提高账户的安全性。

6490

2023.09.14

登录token无效怎么办
登录token无效怎么办

登录token无效的解决办法有检查Token是否过期、检查Token是否正确、检查Token是否被篡改、检查Token是否与用户匹配、清除缓存或Cookie、检查网络连接和服务器状态、重新登录或请求新的Token、联系技术支持或开发人员等。本专题为大家提供token相关的文章、下载、课程内容,供大家免费下载体验。

839

2023.09.14

token怎么获取
token怎么获取

获取token值的方法:1、小程序调用“wx.login()”获取 临时登录凭证code,并回传到开发者服务器;2、开发者服务器以code换取,用户唯一标识openid和会话密钥“session_key”。想了解更详细的内容,可以阅读本专题下面的文章。

1088

2023.12.21

token什么意思
token什么意思

token是一种用于表示用户权限、记录交易信息、支付虚拟货币的数字货币。可以用来在特定的网络上进行交易,用来购买或出售特定的虚拟货币,也可以用来支付特定的服务费用。想了解更多token什么意思的相关内容可以访问本专题下面的文章。

1793

2024.03.01

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

48

2026.02.28

热门下载

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

精品课程

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

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