通过重定向配合查询参数传递验证错误数组,并在表单页解析显示,是 php 原生开发中实现“后端校验 → 前端反馈”最简洁可靠的方式。
在核心 PHP 项目中,表单提交后跳转至独立控制器(如 RegistrationController.php)进行数据验证,是一种常见且职责分离的设计。但需注意:不能直接 include 或 require 表单页来显示错误——这会破坏请求-响应流程,导致重复提交、CSRF 风险及状态混乱。正确做法是使用 HTTP 302 重定向 + 查询参数(Query String) 将错误信息安全传回原始表单页(如 sign-up.php)。
// Controllers/RegistrationController.php
$errors = Validator::validateUser($data);
if (empty($errors)) {
// ✅ 验证通过:执行数据库插入等逻辑
// $user = User::create($data);
// $_SESSION['success'] = '注册成功!';
header('Location: ./sign-up.php?status=success');
exit;
} else {
// ❌ 验证失败:将错误数组作为 URL 参数重定向回 sign-up.php
$query = http_build_query(['errors' => $errors]);
header("Location: ./sign-up.php?$query");
exit;
}⚠️ 注意:exit 或 die() 必须紧跟 header() 后调用,防止后续代码意外执行;路径建议使用相对路径(如 ./sign-up.php)或完整 URL(如 https://yoursite.com/sign-up.php),避免协议/域名缺失问题。
该方案轻量、无 JS 依赖、兼容所有浏览器,是原生 PHP 表单验证反馈的经典实践。