php头文件只有在html表单完全填充时才起作用

a2mppw5e  于 2021-06-18  发布在  Mysql
关注(0)|答案(1)|浏览(304)

我试着做一个页面让用户输入一些信息(名字,姓氏);但是,用户也可以选择不在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;
                    }
              }
  ?>
inn6fuwd

inn6fuwd1#

上的第2页出现语法错误 if (isset($_POST['job_title']) ,可能少了一个 && 就像第一页。

相关问题