我试图使页面供用户输入一些信息(名字,姓氏);但是,用户也可以选择不在HTML表单中输入任何信息,并且可以单击“提交”按钮将其保留为空白。如果用户将HTML表单留空并将其输入到MySQL表中,则该页面将为用户提供给定的数据或创建默认数据。
在处理完MySQL数据后,它使用PHP标头重定向到另一个页面。另一页的目标相同,但数据(职位,雇主名称)不同。第二页的不同之处在于,它具有两个提交按钮-一个允许用户添加另一组数据(职位,雇主姓名),另一个用于将其重定向到下一页。
我已经成功完成了首页创建的用户创建数据的收集,如果保留为空白,它将处理默认的MySQL数据。然后,它成功重定向到下一页。在第2页上,它只能处理HTML表单中的完整用户数据,但是如果任何内容保留为空白(或者表单完全为空白),它将不会处理默认数据,而是直接重定向回自身而不处理MySQL。
我不知道为什么第2页不处理默认数据,然后重定向到第3页。
每个页面(pdo.php)开头的要求仅是创建pdo对象和连接。
我在这里简化了代码:
第1页:
<?php
session_start();
require_once "pdo.php";
if (isset($_POST['first_name']) &&
isset($_POST['last_name']))
{
$sql1 = "INSERT INTO Users (first_name,
last_name)
VALUES(:first_name,
:last_name)";
$stmt1 = $pdo->prepare($sql1);
$stmt1->execute(array(
':first_name' =>
(empty($_POST['first_name']))
? 'NoFirstNameGiven' :
$_POST['first_name'],
':last_name' =>
(empty($_POST['last_name']))
? 'NoLastNameGiven' :
$_POST['last_name']));
header("Location: page2.php");
exit;
}
?>
第2页:
<?php
session_start();
require_once "pdo.php";
if (isset($_POST['job_title']) &&
isset($_POST['employer_name']))
{
$sql = "INSERT INTO Employment
(job_title, employer_name)
VALUES(:job_title, :employer_name)";
$stmt = $pdo->prepare($sql);
$stmt->execute(array(
':job_title' =>
(empty($_POST['job_title']))
? 'NoJobTitleGiven' :
$_POST['job_title'],
':employer_name' =>
(empty($_POST['employer_name']))
? 'NoEmployerGiven' :
$_POST['employer_name']));
if(isset($_POST['nextButton'])){
header("Location: page2.php");
exit;
}
if(isset($_POST['add_job'])){
header("Location: page3.php");
exit;
}
}
?>
答案 0 :(得分:-1)
在if (isset($_POST['job_title'])
的第2页上存在语法错误,就像第1页一样,它可能缺少&&
。