avatar.alex Posted January 26, 2010 Share Posted January 26, 2010 I have an error I can't figure out the problem? Fatal error: Call to a member function recordcount() on a non-object in /home/alexdee/public_html/game/index.php on line 30 Quote Link to comment https://forums.phpfreaks.com/topic/189884-call-to-a-member/ Share on other sites More sharing options...
salathe Posted January 26, 2010 Share Posted January 26, 2010 On (or near) line 30, you'll have code that looks like ->recordcount( which is causing an issue. Diagnosing the precise cause (other than the variable to which it is attached not being an object) needs us to see a sample of the code. If the script isn't too long (nor contains sensitive information) please post it here, or at least a portion of the script surrounding line 30. Edit: typos Quote Link to comment https://forums.phpfreaks.com/topic/189884-call-to-a-member/#findComment-1001948 Share on other sites More sharing options...
avatar.alex Posted January 26, 2010 Author Share Posted January 26, 2010 <?php /*************************************/ /* ezRPG script */ /* Written by Zeggy */ /* http://code.google.com/p/ezrpg */ /* http://www.ezrpgproject.com/ */ /*************************************/ include("lib.php"); define("PAGENAME", "Register"); $msg1 = "<font color=\"red\">"; //Username error? $msg2 = "<font color=\"red\">"; //Password error? $msg3 = "<font color=\"red\">"; //Verify Password error? $msg4 = "<font color=\"red\">"; //Email error? $msg5 = "<font color=\"red\">"; //Verify Email error? $error = 0; if ($_POST['register']) { //Check if username has already been used $query = $db->execute("select `id` from `players` where `username`=?", array($_POST['username'])); //Check username if (!$_POST['username']) { //If username isn't filled in... $msg1 .= "You need to fill in your username!<br />\n"; //Add to error message $error = 1; //Set error check } else if (strlen($_POST['username']) < 3) { //If username is too short... $msg1 .= "Your username must be longer than 3 characters!<br />\n"; //Add to error message $error = 1; //Set error check } else if (!preg_match("/^[-_a-zA-Z0-9]+$/", $_POST['username'])) { //If username contains illegal characters... $msg1 .= "Your username may contain only alphanumerical characters!<br />\n"; //Add to error message $error = 1; //Set error check } else if ($query->recordcount() > 0) { $msg1 .= "That username has already been used. Please create only one account, Creating more than one account will get all your accounts deleted!<br />\n"; $error = 1; //Set error check } //Check password if (!$_POST['password']) { //If password isn't filled in... $msg2 .= "You need to fill in your password!<br />\n"; //Add to error message $error = 1; //Set error check } else if ($_POST['password'] != $_POST['password2']) { $msg3 .= "You didn't type in both passwords correctly!<br />\n"; $error = 1; } else if (strlen($_POST['password']) < 3) { //If password is too short... $msg2 .= "Your password must be longer than 3 characters!!<br />\n"; //Add to error message $error = 1; //Set error check } else if (!preg_match("/^[-_a-zA-Z0-9]+$/", $_POST['password'])) { //If password contains illegal characters... $msg2 .= "Your password may contain only alphanumerical characters!<br />\n"; //Add to error message $error = 1; //Set error check } //Check email if (!$_POST['email']) { //If email address isn't filled in... $msg4 .= "You need to fill in your email!<br />\n"; //Add to error message $error = 1; //Set error check } else if ($_POST['email'] != $_POST['email2']) { $msg5 .= "You didn't type in both email address correctly!"; $error = 1; } else if (strlen($_POST['email']) < 3) { //If email is too short... $msg4 .= "Your email must be longer than 3 characters!<br />\n"; //Add to error message $error = 1; //Set error check } else if (!preg_match("/^[-!#$%&\'*+\\.\/0-9=?A-Z^_`{|}~]+@([-0-9A-Z]+\.)+([0-9A-Z]){2,4}$/i", $_POST['email'])) { $msg4 .= "Your email format is wrong!<br />\n"; //Add to error message $error = 1; //Set error check } else { //Check if email has already been used $query = $db->execute("select `id` from `players` where `email`=?", array($_POST['email'])); if ($query->recordcount() > 0) { $msg4 .= "That email has already been used. Please create only one account, Creating more than one account will get all your accounts deleted!<br />\n"; $error = 1; //Set error check } } if ($error == 0) { $insert['username'] = $_POST['username']; $insert['password'] = sha1($_POST['password']); $insert['email'] = $_POST['email']; $insert['registered'] = time(); $insert['last_active'] = time(); $insert['ip'] = $_SERVER['REMOTE_ADDR']; $query = $db->autoexecute('players', $insert, 'INSERT'); if (!$query) { $could_not_register = "Sorry, you could not register! Please contact the admin!<br /><br />"; } else { $insertid = $db->Insert_ID(); include("templates/header.php"); echo "Congratulations! You have successfully registered!<br />You may login to the game now."; include("templates/footer.php"); exit; } } } $msg1 .= "</font>"; //Username error? $msg2 .= "</font>"; //Password error? $msg3 .= "</font>"; //Verify Password error? $msg4 .= "</font>"; //Email error? $msg5 .= "</font>"; //Verify Email error? include("templates/header.php"); ?> <?=$could_not_register?> <form method="POST" action="register.php"> <table width="100%"> <tr><td width="40%"><b>Username</b>:</td><td><input type="text" name="username" value="<?=$_POST['username'];?>" /></td></tr> <tr><td colspan="2">Enter the username that you will use to login to your game. Only alpha-numerical characters are allowed.<br /><?=$msg1;?><br /></td></tr> <tr><td width="40%"><b>Password</b>:</td><td><input type="password" name="password" value="<?=$_POST['password'];?>" /></td></tr> <tr><td colspan="2">Type in your desired password. Only alpha-numerical characters are allowed.<br /><?=$msg2;?><br /></td></tr> <tr><td width="40%"><b>Verify Password</b>:</td><td><input type="password" name="password2" value="<?=$_POST['password2'];?>" /></td></tr> <tr><td colspan="2">Please re-type your password.<br /><?=$msg3;?><br /></td></tr> <tr><td width="40%"><b>Email</b>:</td><td><input type="text" name="email" value="<?=$_POST['email'];?>" /></td></tr> <tr><td colspan="2">Enter your email address. Only alpha-numerical characters are allowed.<br /><?=$msg4;?><br /></td></tr> <tr><td width="40%"><b>Verify Email</b>:</td><td><input type="text" name="email2" value="<?=$_POST['email2'];?>" /></td></tr> <tr><td colspan="2">Please re-type your email address.<br /><?=$msg5;?><br /></td></tr> <tr><td colspan="2" align="center"><input type="submit" name="register" value="Register!"></td></tr> </table> </form> <?php include("templates/footer.php"); ?> Here's the error in the above too. Fatal error: Call to a member function recordcount() on a non-object in /home/alexdee/public_html/game/register.php on line 38 Quote Link to comment https://forums.phpfreaks.com/topic/189884-call-to-a-member/#findComment-1001953 Share on other sites More sharing options...
avatar.alex Posted January 26, 2010 Author Share Posted January 26, 2010 Same error on register.php sorry. Quote Link to comment https://forums.phpfreaks.com/topic/189884-call-to-a-member/#findComment-1001955 Share on other sites More sharing options...
salathe Posted January 26, 2010 Share Posted January 26, 2010 Where did you get the idea to use $query->recordcount() from? It looks like $query should either by a resource or boolean (true/false), not an object. Try $db->numRows($query) instead. Quote Link to comment https://forums.phpfreaks.com/topic/189884-call-to-a-member/#findComment-1001957 Share on other sites More sharing options...
PFMaBiSmAd Posted January 26, 2010 Share Posted January 26, 2010 If the query successfully executes without error, it probably returns a result object. However, your query is failing. What database class are you using so that someone could try to determine what error checking and error reporting it has that could be used to find out why your query is failing? Edit: and are you trying this on a system with error_reporting set to E_ALL so that all php errors (not just fatal ones) would be reported? Quote Link to comment https://forums.phpfreaks.com/topic/189884-call-to-a-member/#findComment-1001963 Share on other sites More sharing options...
avatar.alex Posted January 26, 2010 Author Share Posted January 26, 2010 im using this thing called adodb. Quote Link to comment https://forums.phpfreaks.com/topic/189884-call-to-a-member/#findComment-1002052 Share on other sites More sharing options...
PFMaBiSmAd Posted January 26, 2010 Share Posted January 26, 2010 Add the following line of code before the first $db->execute() statement - $db->debug=true; Quote Link to comment https://forums.phpfreaks.com/topic/189884-call-to-a-member/#findComment-1002065 Share on other sites More sharing options...
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.