如何在 PHP 联系表单中实现错误时保留输入、成功后清空字段并显示提示

16次阅读

如何在 PHP 联系表单中实现错误时保留输入、成功后清空字段并显示提示

本文介绍一种健壮的 php 表单处理模式:当用户提交失败时自动保留已填内容便于修正;提交成功后重定向至带提示参数的页面,既清空表单又避免重复提交,同时确保“邮件已发送”消息可靠显示。

在构建联系表单时,良好的用户体验要求:出错时保留用户输入(避免重复填写),成功后清空表单并明确反馈结果。直接在 $_POST 中 unset() 或依赖页面刷新无法兼顾两者——因为 $_POST 数据仅存在于当前请求生命周期,且未重定向会导致 F5 刷新重复提交。

✅ 正确做法是采用 POST-redirect-GET(PRG)模式

  1. 接收 POST 请求 → 验证并发送邮件
  2. 若成功 → 用 header(‘location: contact.php?sent’) 重定向到自身带查询参数的 GET 请求
  3. 在 GET 请求中显示成功提示,并渲染一个全新、干净的表单

以下是完整、安全、可扩展的 contact.php 示例(已移除硬编码邮箱,增强可读性):

表单提交(POST) elseif ($_SERVER['REQUEST_METHOD'] === 'POST') {     // 基础验证(生产环境应使用更严格的过滤,如 filter_input())     $name  = trim($_POST['name'] ?? '');     $email = filter_var($_POST['email'] ?? '', FILTER_SANITIZE_EMAIL);     $msg   = trim($_POST['msg'] ?? '');      if (empty($name) || empty($email) || empty($msg)) {         $error = '请填写所有必填字段。';     } elseif (!filter_var($email, FILTER_VALIDATE_EMAIL)) {         $error = '请输入有效的邮箱地址。';     } else {         // 构建邮件头防止注入(关键!)         $headers = "From: {$name} <{$email}>rn" .                    "Reply-To: {$email}rn" .                    "X-Mailer: PHP/" . phpversion();          // 发送邮件(建议改用 PHPMailer 或 SMTP 提升可靠性)         if (mail('your@example.com', '网站联系表单', $msg, $headers)) {             header('Location: contact.php?sent');             exit;         } else {             $error = '邮件发送失败,请稍后重试。';         }     } } ?>        

✅ 您的邮件已成功发送!

⚠️







? 关键要点说明:

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

  • header(‘Location: …’) + exit 是核心:强制跳转后,浏览器发起新 GET 请求,$_POST 彻底失效,表单自然清空;
  • htmlspecialchars() 必须调用:防止 xss 攻击,尤其回显用户输入时;
  • filter_var() 过滤邮箱:比简单 trim() 更安全;
  • 邮件头防御:手动构造 From 和 Reply-To 时需严格校验,避免邮件头注入;
  • ⚠️ mail() 函数局限性:开发阶段可用,上线建议切换至 PHPMailer 或 SMTP 服务(如 SendGrid),以保障送达率与错误追踪能力。

通过该方案,用户再也不会遇到“发完邮件还留着旧数据”或“刷新后提示消失”的问题——它兼顾了健壮性、安全性与用户体验。

text=ZqhQzanResources