php删除数据怎么防止误删_二次确认机制代码实现【方法】

PHP删除必须服务端二次确认、POST提交、校验数据归属、预处理SQL、重定向防重复。关键在于隔离确认与执行流程,并验证用户权限,否则易致越权或误删。

PHP 删除前必须拦截用户操作

直接执行 DELETE 语句没有任何防护,一旦点击就删,连 Undo 都没有。真实项目里,所有可删除入口都得强制加二次确认——不是靠 JS 弹窗“确定吗?”这种容易被绕过的前端提示,而是服务端必须验证用户是否明确触发了“确认删除”动作。

用隐藏字段 + 表单状态区分“点击删除”和“确认删除”

常见错误是把删除逻辑写在 GET 请求里(比如 /delete.php?id=123),这会导致浏览器刷新、爬虫抓取甚至 Referer 泄露时误删。正确做法是用 POST 表单,并通过一个隐藏字段标识当前请求阶段:


后端判断 $_POST['step'] === 'confirm' 才执行 SQL;否则只渲染确认页面。这样即使用户刷新确认页,也不会重复提交删除。

数据库操作前必须查一遍是否存在且归属当前用户

防止越权删除的关键不是“用户点了确认”,而是“用户有权删这条”。不能只校验登录态,必须查库确认该记录的 user_id 或权限字段匹配当前会话:

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

  • SELECT id FROM posts WHERE id = ? AND user_id = ? —— 查不到就直接报错或跳回列表页
  • 别用 DELETE FROM posts WHERE id = ? 直接删,要带上归属条件:DELETE FROM posts WHERE id = ? AND user_id = ?
  • 用 PDO 预处理,避免拼接 ID 导致 SQL 注入:$stmt = $pdo->prepare("DELETE FROM posts WHERE id = ? AND user_id = ?");

删完必须重定向,禁止留在原页面

删完如果还留在 POST 页面,用户按 F5 就会再次提交——这是最常被忽略的坑。删成功后务必用 header('Location: /posts') 跳转,且跳转前要确保事务已提交或错误已捕获。

更稳妥的做法是删完跳转到带提示的页面,比如:header('Location: /posts?msg=deleted'),然后在列表页读取 $_GET['msg'] 显示绿色提示。这样既防重复提交,又给用户明确反馈。

真正危险的不是不会写 SQL,而是没把「确认动作」和「执行动作」在流程上彻底隔离,也没校验数据归属。只要漏掉其中一环,删库跑路就只是多点一次鼠标的事。