PHP标头仅在完全填写html表单时起作用

时间:2018-12-09 22:08:41

标签: php mysql redirect post header

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

1 个答案:

答案 0 :(得分:-1)

if (isset($_POST['job_title'])的第2页上存在语法错误,就像第1页一样,它可能缺少&&