PHP使用输入值进行更新


PHP update using input value

我一直收到以下错误,无法找出问题所在。

注意:第99行C:''examplep''htdocs''FYP''resProcessing.php中的未定义索引:name

错误与以下行有关:

$name = $_POST['name'];

以下是我的代码:

if ($quick_check != 0){
    while ($row = mysqli_fetch_array($query, MYSQLI_ASSOC)){
        $id = $row['id'];
        $tablenum = $row['tablenum'];
        $avail = $row['avail'];
        $spots .= 'You just reserved table '.$tid.'.<br />';
        $spots .= 'You only have 8 minutes to finish or your reservation will expire and the table will open up to other people.<br />';
    }
    $availNow = $avail - $num;
    $sql = "UPDATE available SET avail='$availNow' WHERE id='$id' LIMIT 1";
    $query = mysqli_query($connect, $sql);
    $sql = "INSERT INTO reserves(tablenumber,numseats,restime) VALUES ('$tablenum','$num',now())";
    $query = mysqli_query($connect, $sql);
    $reserveID = mysqli_insert_id($connect);
    $spots .= '<form name="confirmform" id="confirmform" method="post" onSubmit="return false;">';
    $spots .= 'Full Name: &nbsp;<input type="text" name="name" id="name" required autofocus placeholder="Your Name" pattern="[a-zA-Z]+{3,}" title="Please enter your full name."></br>';
    // hidden field holds the table name
    $spots .= '<input id="tableNumber" type="hidden" value="'.$tablenum.'">';
    // hidden field holds the number of seats
    $spots .= '<input id="numSeats" type="hidden" value="'.$num.'">';
    // hidden field holds the reserve insert id
    $spots .= '<input id="reserveID" type="hidden" value="'.$reserveID.'">';
    // On submit call js function
    $spots .= '<button id="confirmbtn" onClick="confirmSeats();updateInfo();">Make Reservations</button></br>';
    $name = $_POST['name'];
    $sql = "UPDATE available SET name='$name' WHERE id='$id' LIMIT 1";
    $query = mysqli_query($connect, $sql);
    $spots .= '</form>';
    $spots .= '<button id="cancelbtn" onClick="cancelReserve('.$reserveID.')">Cancel Reservation</button>';

} else {
    $spots .= "Sorry, someone just reserved those. Try another table";
    $reserveID = "open";
}           
echo "$spots|$reserveID";
exit();
}

如果有人能帮忙,我将不胜感激。谢谢

原因是POST请求不包含name参数。

或者HTTP请求类型不是POST。

试试$name = $_REQUEST['name'];——它也会考虑GET变量(和cookie)。如果没有帮助,请修复您的客户端(无论是HTML表单、JavaScript还是其他什么)。

您还可以在尝试访问POST变量之前检查是否定义了该变量,例如:

if (isset($_POST['name']))
{ 
    $name = $_POST['name'];
} 
else 
{ 
    echo "Name is required"; 
    // ...
}

信息:

听起来$_POST['name']没有定义。你应该验证它是否是,如果不是,你应该有一些逻辑来处理这种情况。您可以使用PHP isset()来检查$_POST['name']是否"已设置"。

警告:

其他人可能建议使用$_REQUEST,以防您的变量也可能设置在$_GET上,但在简单地使用$_REQUEST之前,您应该了解RESTful API是如何工作的,因为可能会影响业务逻辑和/或安全考虑因素。

奖金:

您可能还想了解一些PHP框架,例如Laravel。