PHP 注册系统无法工作(phpmyadmin、wampserver)

标签 php mysql system

我的 php 注册系统不会连接到我本地托管的 phpmyadmin 数据库,即使我已经检查了拼写错误并且一切看起来都应该有效。即使 PHP 注册脚本中已声明, header 也不会更改。没有任何内容被传输到我的数据库中(没有错误)。如果有人能告诉我我做错了什么那就太好了。 (P.S. footer.php 和 header.php 是正确的并包含在表单中)

注册错误处理程序并注册脚本:

<?php

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

include_once 'dbh.inc.php';

$first = mysqli_real_escape_string($conn, $_POST)$_POST['first'];
$last = mysqli_real_escape_string($conn, $_POST)$_POST['last'];
$email = mysqli_real_escape_string($conn, $_POST)$_POST['email'];
$username = mysqli_real_escape_string($conn, $_POST)$_POST['username'];
$password = mysqli_real_escape_string($conn, $_POST)$_POST['password'];

//Error handlers
//Check for empty fields
if (empty($first)) || (empty($last)) || (empty($email)) || 
(empty($username)) || (empty($password)) {
    header("Location: ../signup.php?signup=empty");
    exit();
} else {
    //Check is 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=empty");
            exit();
        } else {
            $sql = "SELECT * FROM users WHERE user_username='username'";
            $result = mysqli_query($conn, $sql);
            $resultCheck = mysqli_num_rows($result);

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

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

数据库连接:

<?php

$dbServername = "localhost";
$dbUsername = "root";
$dbPassword = "";
$dbServername = "loginsystem";

$conn = mysqli_connect($dbServername, $dbUsername, $dbPassword, 
$dbServername);

注册表单(php 文件中的 html):

<?php include_once 'header.php';?>

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

<?php include_once 'footer.php';?>

如果可以的话请帮忙。我们将不胜感激。谢谢!

最佳答案

将 HTML 注册页面的提交按钮命名为“提交”:

 <button type="submit" name="submit">Sign Up!</button> 

更改 PHP 注册页面 POST:

$first = mysqli_real_escape_string($conn, $_POST['first']);
$last = mysqli_real_escape_string($conn, $_POST['last']);
$email = mysqli_real_escape_string($conn, $_POST['email']);
$username = mysqli_real_escape_string($conn, $_POST['username']);
$password = mysqli_real_escape_string($conn, $_POST['password']);

将 stmt 的空值检查更改为:

if ( (empty($first)) || (empty($last)) or (empty($email)) || (empty($username)) || (empty($password)) )

将输入字符有效性检查 if stmt 更改为:

if ( (!preg_match("/^[a-zA-Z]*$/", $first)) || ((!preg_match("/^[a-zA-Z]*$/", $last)) ) )

关于PHP 注册系统无法工作(phpmyadmin、wampserver),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47543511/

相关文章:

javascript - 如何模仿PHP? JavaScript 中的双问号行为?

php - 为什么PHP中的backtrace为什么在PHP中使用debug_backtrace()和debug_print_backtrace()函数?

php - 如何通知mysql中的元素与输入相同?

Java 安装程序。如何设置Windows系统路径?

php - 像 Facebook 一样上传多张照片

php - Wordpress 导航菜单悬停状态和下拉菜单工作,但菜单不可点击

php - (SQL) 更新包含空外键错误的行

mysql - where 查询将字段从人类日期转换为 unix 时间戳并确保仅在上个月

networking - 阻塞操作和 ZeroMQ

linux - 为什么用 vim 文本编辑器打开目标文件(linux 中的 .o 文件)时看起来是乱码?