Следил за видео, и то, что должно работать просто отлично, дает мне ошибку. Я получаю ошибку WHOOPS от! Mysqli_stmt_prepare. Может быть, я кое-что пропустил? Видео заставило нас удалить значения вместо "?", Но это никогда не работало для меня, поэтому я просто вставил $ var обратно. Кстати: внутри личного заявления есть только специальные символы (апострофы и кавычки) когда они будут представлены. Я думал, что заявление избежит тех, кто не проблема. Спасибо.
<?php
header('Refresh:3; url=/Collaborate/');
$link = mysqli_connect("*****","*****","*****", "*****");
if (!$link) {
echo "Error: Unable to connect to MySQL." . PHP_EOL;
echo "Debugging errno: " . mysqli_connect_errno() . PHP_EOL;
echo "Debugging error: " . mysqli_connect_error() . PHP_EOL;
exit;
}
$Fname = $_POST['Fname'];
$Lname = $_POST['Lname'];
$Website = $_POST['Website'];
$Phone = $_POST['Phone'];
$Email = $_POST['Email'];
$Interests1 = $_POST['Int1'];
$Interests2 = $_POST['Int2'];
$Interests3 = $_POST['Int3'];
$PersonalStatement = $_POST['PersonalStatement'];
// BAD ESCAPE. BAD!
// array_walk_recursive($link, $_POST, 'mysqli_real_escape_string' );
$sql = "INSERT INTO User(Fname, Lname, Website, Phone, Email, Interest1, Interest2, Interest3, PersonalStatement) VALUES(?, ?, ?, ?, ?, ?, ?, ?, ?);";
$stmt = mysqli_stmt_init($link);
if (!mysqli_stmt_prepare($stmt, "sssssssss", $sql)) {
echo "WHOOPS!";
} else {
mysqli_stmt_bind_param($stmt, $Fname, $Lname, $Website, $Phone, $Email, $Interests1, $Interests2, $Interests3, $PersonalStatement);
mysqli_stmt_execute($stmt);
echo "<h2>We got you $Fname!</h2>";
}
?>