我试着做一个页面让用户输入一些信息(名字,姓氏);但是,用户也可以选择不在html表单中输入任何信息,并可以单击submit按钮将其留空。如果用户将html表单留空并将其输入到mysql表中,则该页将获取用户给定的数据或创建默认数据。
在处理mysql数据之后,它使用php头重定向到另一个页面。另一个页面的目标相同,但数据不同(职务、雇主名称)。第二个页面的不同之处在于它有两个提交按钮—一个允许用户添加另一组数据(职务、雇主名称),另一个允许用户将其重定向到下一个页面。
我成功地收集了第一个页面的用户创建的数据,如果留空,它将处理默认的mysql数据。然后它成功地重定向到下一页。在第2页,它只能处理html表单中已完成的用户数据,但是如果有任何内容留空(或者如果表单完全为空),它将不会处理默认数据,只会重定向回自己,而不处理mysql。
我不知道为什么第2页不处理默认数据,然后重定向到第3页。
每个页面开头的require once(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条答案
按热度按时间inn6fuwd1#
上的第2页出现语法错误
if (isset($_POST['job_title'])
,可能少了一个&&
就像第一页。