PHP 注册表单不工作

标签 php mysql html forms

<分区>

我正在构建这个 PHP 登录系统来提高我的技能。当用户注册并且他们的信息在 SQL 数据库中受到保护时,我想在屏幕顶部显示 signup.php?signup=success。当用户输入信息并且似乎缺少某些内容时,我希望它显示 signup.php?signup=empty。

但是,在我当前的页面上,即使我输入信息,它也会继续显示 signup.php?signup=empty。我知道我的数据库肯定能正常工作....

这是我的 signup.inc.php 的 PHP 代码(包含在 includes 文件夹中):

<?php

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

    include_once 'dbh.php';

    $first = mysqli_real_escape_string($conn, $_POST['first']);
    $last = mysqli_real_escape_string($conn, $_POST['last']);
    $email = mysqli_real_escape_string($conn, $_POST['email']);
    $uid = mysqli_real_escape_string($conn, $_POST['uid']);
    $pwd = mysqli_real_escape_string($conn, $_POST['pwd']);

    //Error handlers
    //Check for empty fields
    if (empty($first) || empty($last) || empty($email) || empty($uid) || empty($pwd)) {
        header("Location: ../signup.php?signup=empty");
        exit();
    } else {
        //Check if input characters are valid
        if (!preg_match("/^[a-zA-Z]*$/", $first) || !preg_match("/^[a-zA-Z]*$/", $last)) {
            header("Location: ../signup.php?signup=invalid");
            exit();
        } else {
            //Check if email is valid
            if (!filter_var($email, FILTER_VALIDATE_EMAIL)) {
                header("Location: ../signup.php?signup=email");
                exit();
            } else {
                $sql = "SELECT * FROM users WHERE user_uid='$uid'";
                $result = mysqli_query($conn, $sql);
                $resultCheck = mysqli_num_rows($result);

                if ($resultCheck > 0) {
                    header("Location: ../signup.php?signup=usertaken");
                    exit();
                } else {
                    //Hashing the password
                    $hashedPwd = password_hash($pwd, PASSWORD_DEFAULT);
                    //Insert the user into the database
                    $sql = "INSERT INTO users (user_first, user_last, user_email, user_uid, user_pwd) VALUES ('$first', '$last', '$email', '$uid', '$hashedPwd');";
                    mysqli_query($conn, $sql);
                    header("Location: ../signup.php?signup=success");
                    exit();
                }
            }
        }
    }

} else {
    header("Location: ../signup.php");
    exit();
}

这是我的 signup.php 表单(我包含了包含数据库的 header.php):

<?php 

  include 'header.php';

?>

    <section class="main-container">
      <div class="main-wrapper">
         <h2>Signup</h2>
         <form class="signup-form" action="includes/signup.inc.php" method="POST">
           <input type="text" name="first" placeholder="First Name">
           <input type="text" name="last" placeholder="Last Name">
           <input type="text" name="email" placeholder="Email">
           <input type="text" name="uid" placeholder="Username">
           <input type="password" name="password" placeholder="password">
           <button type="submit" name="submit">Sign Up</button>
         </form>
      </div>
    </section>

    <?php

    include 'footer.php';

    ?>

我做错了什么?

感谢所有回复

最佳答案

只需更改:

<input type="password" name="password" placeholder="password">

收件人:

<input type="password" name="pwd" placeholder="password">

因为在您的 php 中,您使用的是索引 pwd 而不是 password 而从您的 html 中您发送的是 password 而不是 pwd

关于PHP 注册表单不工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47242887/

相关文章:

javascript - jQuery FadeIn 如何知道使用的显示模式?

php - 在从 PHP 发送的电子邮件中使用 HTML 格式

php - 诊断 "The connection to localhost was interrupted"

php - 将 img 标签转换为 amp-img 的最佳方法是什么?

mysql - 如何使用jsp servlet代码将文件路径和文件名存储到数据库(mysql)中?

javascript - 每行开头和结尾的填充相同

php - CodeIgniter DataMapper ORM 无法实例化模型对象

mysql - 我可以执行一个只返回与通配符匹配的列的数据的查询吗?

c# - 如何保存MySql连接?

html - 与 Chrome 相比,为什么 Bootstrap 3 日期输入在 Firefox 中看起来不同?