您好,我有同樣的問題,但很困惑,爲什麼它不起作用。致命錯誤:調用布爾型成員函數close()
Fatal error: Call to a member function close() on boolean in includes\register_check.php on line 45
這是$ stmt3-> close();
代碼
} else {
if (strlen($_POST['username2']) < 2 || strlen($_POST['username2']) > 20) {
echo "<h3>Username must be between 2 and 20 characters!</h3>";
} else {
$stmt = yasDB_select("SELECT `id` FROM `user` WHERE `username` LIKE '$username'");
$stmt2 = yasDB_select("SELECT `id` FROM `user` WHERE `email` LIKE '$email'");
if ($stmt->num_rows == 0 && $stmt2->num_rows == 0) {
$stmt3 = yasDB_insert("INSERT INTO `user` (`username`, `password`, `repeatpassword`, `name`, `email`, `website`, `plays`, `points`, `date`) VALUES ('$username','$password','$repeatpassword','$name','$email','$website','$plays','$points', '$date')", false);
if ($stmt3) {
echo "<h3>Registered! You may now log in.</h3>";
} else {
$stmt3->close();
echo "<h3>Registration failed!</h3>";
}
} else {
$stmt->close();
echo "<h3>Sorry, username or email exists. Please try again.</h3>";
}
}
}
我懷疑這是因爲'$ stmt3'爲空。你從else調用它,if檢查的值不是falsey。你可能想在'if'結果中找到那一行,而不是那個檢查的結果。 – Carl
Sry我的意思是$ stmt3-> close();這給出了錯誤。 – funkstar33
雖然你正在修復的東西,你可能還想檢查http://stackoverflow.com/questions/60174/how-can-i-prevent-sql-injection-in-php – apokryfos