2013-09-30 247 views
0

我已经通过代码再次手动和使用代码检查程序,但无法看到我的错误。我正在建立一个注册页面,如果任何一个字段留空或者密码不匹配,这个页面应该会出错。表单看起来不错,但是当我尝试注册时,我收到错误消息“发生了以下错误 - 请输入密码,请重试。”无论我输入什么密码,都会发生这种情况。注册页面没有注册用户

此外,表单应该记住在给出错误消息时输入的数据,但由于某种原因它会填写姓氏和电子邮件字段,但不是名字。同样,在看剧本时我看不出原因。

我正在从一本基本的书--PHP &学习MySQL,这些步骤可能并不是最好的,但我想在完成其他任务之前完成它。

<!DOCTYPE HTML> 
<html lang="en"> 
<head> 
    <meta charset="UTF-8"> 
    <title>Providing a register page</title> 
</head> 
<body> 
<?php 
$page_title = 'Register' ; 
include ('includes/header.html'); 

if ($_SERVER[ 'REQUEST_METHOD' ] == 'POST') { 
    require ('../connect_db.php'); 
    $errors = array() ; 

    if (empty($_POST[ 'first_name' ])) { 
     $errors[] = 'Enter your first name.'; 
    } else { 
     $fn = mysqli_real_escape_string($dbc, trim($_POST[ 'first_name' ])); 
    } 

    if (empty($_POST[ 'last_name' ])) { 
     $errors[] = 'Enter your last name.'; 
    } else { 
     $ln = mysqli_real_escape_string($dbc, trim($_POST[ 'last_name' ])); 
    } 

    if (empty($_POST[ 'email' ])) { 
     $errors[] = 'Enter your email address.'; 
    } else { 
     $e = mysqli_real_escape_string($dbc, trim($_POST[ 'email' ])); 
    } 

    if (!empty($_POST[ 'pass1' ])) { 
     if ($_POST[ 'pass1' ] != $_POST[ 'pass2' ]) { 
      $errors[] = 'Passwords do not match.'; 
     } else { 
      $p = mysqli_real_escape_string($dbc, trim($_POST[ 'pass1' ])); 
     } 
    } else { 
     $errors[] = 'Enter your password.'; 
    } 
    if (empty($errors)) { 
     $q = "SELECT user_id FROM users WHERE email='$e'"; 
     $r = mysqli_query ($dbc , $q); 
      if (mysqli_num_rows($r) != 0) { 
       $errors[] = 'Email address already registered. <a href="login.php">Login</a>'; 
      } 
    } 

    if (empty($errors)) { 
     $q = "INSERT INTO users (first_name, last_name, email, pass, reg_date) VALUES ('$fn', '$ln', '$e', SHA1('$p'), NOW()"; 
     $r = mysqli_query ($dbc , $q); 

     if ($r) { 
      echo '<h1>Registered!</h1>' 
       .'<p>You are now registered.</p>' 
       .'<p><a href="login.php">Login</a></p>'; 
     } 
    mysqli_close($dbc) ; 
    include ('includes/footer.html'); 
    exit(); 
} else { 
    echo '<h1>Error!</h1>' 
     .'<p id="err_msg">The following error(s) occurred:<br>'; 
    foreach ($errors as $msg) { 
     echo " - $msg<br>"; 
    } 
    echo 'Please try again.</p>'; 
    mysqli_close($dbc); 
} 
?> 

<h1>Register</h1> 
<form action="register.php" method="POST"> 
    <p> 
    First Name: <input type="text" name="first_name" 
     value="<?php if (isset($_POST[ ' first_name' ])) echo $_POST[ 'first_name' ] ; ?>"> 
    Last Name: <input type="text" name="last_name" 
     value="<?php if (isset($_POST[ 'last_name' ])) echo $_POST[ 'last_name' ] ; ?>"> 
    </p><p> 
    Email address: <input type="text" name="email" 
     value="<?php if (isset($_POST[ 'email' ])) echo $_POST[ 'email' ] ; ?>"> 
    </p><p> 
    Password: <input type="password name="pass1" 
     value="<?php if (isset($_POST[ 'pass1' ])) echo $_POST[ 'pass1' ] ; ?>"> 
    Password: <input type="password name="pass2" 
     value="<?php if (isset($_POST[ 'pass2' ])) echo $_POST[ 'pass2' ] ; ?>"> 
    </p><p> 
    <input type="submit" value="Register"> </p> 
</form> 
<?php include ('includes/footer.html') ; ?> 
</body> 
</html> 
+0

请使用''

回答

2

你忘记了一个括号 “)

$q = "INSERT INTO users 
(first_name, last_name, email, pass, reg_date) 
VALUES ('$fn', '$ln', '$e', SHA1('$p'), NOW()) " ; 
              ^^ Here 
+0

括号!=括号 –

+0

@RUJordan ..谢谢:) – aldanux

+0

Gotchu brah! ;) –