我一直收到以下错误,无法找出问题所在。
注意:第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: <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();
}
如果有人能帮忙,我将不胜感激。谢谢
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。