2016-09-26 47 views
-2

您好,我有同样的问题,但很困惑,为什么它不起作用。致命错误:调用布尔型成员函数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>"; 
     } 
    } 
} 
+2

我怀疑这是因为'$ stmt3'为空。你从else调用它,if检查的值不是falsey。你可能想在'if'结果中找到那一行,而不是那个检查的结果。 – Carl

+0

Sry我的意思是$ stmt3-> close();这给出了错误。 – funkstar33

+0

虽然你正在修复的东西,你可能还想检查http://stackoverflow.com/questions/60174/how-can-i-prevent-sql-injection-in-php – apokryfos

回答

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>"; 
     } 

或许应该

 $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) { 
      $stmt3->close(); 
      echo "<h3>Registered! You may now log in.</h3>"; 
     } else { 
      // $stmt3 is falsey (null or false) here, so we cant call close on it. 
      echo "<h3>Registration failed!</h3>"; 
     } 

如别人,$stmt3是falsey(很可能是假的),这是什么原因造成的Call to a member function close() on boolean错误,当您尝试呼吁关闭它。

+0

不工作已经尝试过it.Just说注册失败 – funkstar33

+0

这意味着您的查询:yasDB_insert(“INSERT INTO用户”('用户名','密码','repeatpassword','name','email','网站'$ username','$ password','$ repeatpassword','$ name','$ email','$ website','$ plays' ,'$ points','$ date')“,false); - 失败。 – Carl

+0

是的,我说,当它说注册失败 – funkstar33

相关问题