我试图为用户创建一个页面来输入一些信息(名字,姓氏);但是,用户也可以选择不在HTML表单中输入任何信息,并可以单击“提交”按钮将其留空 . 如果用户将HTML表单留空并将其输入到MySQL表中,则页面将获取用户给定的数据或创建默认数据 .
处理完MySQL数据后,它会使用PHP标头重定向到另一个页面 . 另一页具有相同的目标,但不同的数据(职称,雇主姓名) . 第二页的不同之处在于它有两个提交按钮 - 一个允许用户添加另一组数据(作业 Headers ,雇主名称),另一个用于将其重定向到下一页 .
我已经成功完成了第一页用户创建数据的集合,如果留空,它会处理默认的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;
}
}
?>
1 回答
在
if (isset($_POST['job_title'])
上的page2上存在语法错误,它可能缺少&&
,就像page1一样 .