Jump to content

PHP help debug


xreigninflame

Recommended Posts

im getting an error at the numrows line

 

<?

session_start();

include("database.php");

 

/**

* Returns true if the username has been taken

* by another user, false otherwise.

*/

function usernameTaken($username)

{

  global $conn;

  if(!get_magic_quotes_gpc())

  {

      $username = addslashes($username);

  }

  $q = "select username from users where username = '$username'";

  $result = mysql_query($q,$conn);

  return (mysql_numrows($result) > 0); /*this is the error*/

}

 

/**

* Inserts the given (username, password) pair

* into the database. Returns true on success,

* false otherwise.

*/

function addNewUser($username, $password)

{

  global $conn;

  $q = "INSERT INTO users VALUES ('$username', '$password')";

  return mysql_query($q,$conn);

}

 

/*

  Displays the appropriate message to the user

  after the registration attempt. It displays a

  success or failure status depending on a

  session variable set during registration.

*/

function displayStatus(){

  $uname = $_SESSION['reguname'];

  if($_SESSION['regresult']){

?>

 

<h1>Registered!</h1>

<p>Thank you <b><? echo $uname; ?></b>, your information has been added to the database, you may now <a href="main.php" title="Login">log in</a>.</p>

 

<?

  }

  else{

?>

 

<h1>Registration Failed</h1>

<p>We're sorry, but an error has occurred and your registration for the username <b><? echo $uname; ?></b>, could not be completed.<br>

Please try again at a later time.</p>

 

<?

  }

  unset($_SESSION['reguname']);

  unset($_SESSION['registered']);

  unset($_SESSION['regresult']);

}

 

if(isset($_SESSION['registered'])){

/**

* This is the page that will be displayed after the

* registration has been attempted.

*/

?>

 

<html>

<title>Registration Page</title>

<body>

 

<? displayStatus(); ?>

 

</body>

</html>

 

<?

  return;

}

 

/**

* Determines whether or not to show to sign-up form

* based on whether the form has been submitted, if it

* has, check the database for consistency and create

* the new account.

*/

if(isset($_POST['subjoin'])){

  /* Make sure all fields were entered */

  if(!$_POST['user'] || !$_POST['pass']){

      die('You didn\'t fill in a required field.');

  }

 

  /* Spruce up username, check length */

  $_POST['user'] = trim($_POST['user']);

  if(strlen($_POST['user']) > 30){

      die("Sorry, the username is longer than 30 characters, please shorten it.");

  }

 

  /* Check if username is already in use */

  if(usernameTaken($_POST['user'])){

      $use = $_POST['user'];

      die("Sorry, the username: <strong>$use</strong> is already taken, please pick another one.");

  }

 

  /* Add the new account to the database */

  $md5pass = md5($_POST['pass']);

  $_SESSION['reguname'] = $_POST['user'];

  $_SESSION['regresult'] = addNewUser($_POST['user'], $md5pass);

  $_SESSION['registered'] = true;

  echo "<meta http-equiv=\"Refresh\" content=\"0;url=$HTTP_SERVER_VARS[php_SELF]\">";

  return;

}

else{

/**

* This is the page with the sign-up form, the names

* of the input fields are important and should not

* be changed.

*/

?>

 

<html>

<title>Registration Page</title>

<body>

<h1>Register</h1>

<form action="<? echo $HTTP_SERVER_VARS['PHP_SELF']; ?>" method="post">

<table align="left" border="0" cellspacing="0" cellpadding="3">

<tr><td>Username:</td><td><input type="text" name="user" maxlength="30"></td></tr>

<tr><td>Password:</td><td><input type="password" name="pass" maxlength="30"></td></tr>

<tr><td colspan="2" align="right"><input type="submit" name="subjoin" value="Join!"></td></tr>

</table>

</form>

</body>

</html>

 

 

<?

}

?>

 

 

 

if you could please email me at drummer666@gmail.com with the fix i would be much obliged

 

Thanks so much

Link to comment
Share on other sites

That would indicate that something has gone wrong with the query above that populates $result

 

Can you please post the code as you have it now?  Did you put the "or die(mysql_error());"  after the SELECT query?

Link to comment
Share on other sites

This thread is more than a year old. Please don't revive it unless you have something important to add.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.