我想在MySql數據庫中運行查詢,但我每次都有相同的警告。有人可以幫忙嗎?幫助我有一個錯誤消息使用PHP「警告:mysql_num_rows():提供的參數是不是一個有效的MySQL結果資源...」
警告:mysql_num_rows():提供的參數不是在/XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX/public_html/login.php一個有效的MySQL結果資源上線279 您提供的用戶名不存在!
我強調線279 ++++++++++++ $ NUM = mysql_num_rows($水庫); ++++++++++++
請讓我知道我該如何糾正這個問題。
<?php
//If the user has submitted the form
if($_POST['submit']) {
//protect the posted value then store them to variables
$username = protect($_POST['username']);
$password = protect($_POST['password']);
//Check if the username or password boxes were not filled in
if(!$username || !$password) {
//if not display an error message
echo "<center>You need to fill in a <b>Username</b> and a <b>Password</b>!</center>";
} else {
//if the were continue checking
//select all rows from the table where the username matches the one entered by the user
$res = mysql_query("SELECT *
FROM `users`
WHERE `username` = '".$username."'");
++++++++++++++$num = mysql_num_rows($res);++++++++++++++++++
//check if there was not a match
if($num == 0) {
//if not display an error message
echo "<center>The <b>Username</b> you supplied does not exist!</center>";
} else {
//if there was a match continue checking
//select all rows where the username and password match the ones submitted by the user
$res = mysql_query("SELECT * FROM `users`
WHERE `username` = '".$username."'
AND `password` = '".$password."'");
$num = mysql_num_rows($res);
//check if there was not a match
if($num == 0) {
//if not display error message
echo "<center>The <b>Password</b> you supplied does not match the one for that username!</center>";
} else {
//if there was continue checking
//split all fields fom the correct row into an associative array
$row = mysql_fetch_assoc($res);
//check to see if the user has not activated their account yet
if($row['active'] != 1){
//if not display error message
echo "<center>You have not yet <b>Activated</b> your account!</center>";
}else{
//if they have log them in
//set the login session storing there id - we use this to see if they are logged in or not
$_SESSION['uid'] = $row['id'];
//show message
echo "<center>You have successfully logged in!</center>";
//update the online field to 50 seconds into the future
$time = date('U')+50;
mysql_query("UPDATE `users` SET `online` = '".$time."' WHERE `id` = '".$_SESSION['uid']."'");
//redirect them to the usersonline page
header('Location: usersOnline.php');
}
}
}
}
}
?>
保護功能在做什麼? – Ibu 2011-05-29 22:14:14
您的錯誤表示您的查詢不正確 – Ibu 2011-05-29 22:14:52
可能的重複[警告:mysql_fetch_ *期望參數1是資源,布爾給定錯誤](http://stackoverflow.com/questions/11674312/warning-mysql-fetch-expects-參數-1要資源布爾錯誤) – 2012-08-02 12:54:23