首先,我要说的是,我在这方面是非常新的。我正在尝试开发一个移动应用程序和一个没有实际经验的网站。有可能是我错过了什么,或者我做错了什么,但我似乎无法指出问题所在。在创建我自己的之前,我遵循了一个视频指南(将演示文件下载到我的计算机上),但似乎无法连接到我的数据库。我还复制了演示文件,并将它们放入我的代码中,它仍然让我抓到一个部分。我用mamp程序连接,用括号表示代码。以下是我的会话文件:
数据库连接-

<?php

$dbServername = "localhost";
$dbUsername = "root";
$dbPassword = "root";
$dbName = "Login System";

$con = mysqli_connect($dbServername, $dbUsername, $dbPassword, $dbName);

我的注册文档-
<?php

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

    include_once 'dbh.inc.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)) {
        echo <h2>Please fill in all fields;
        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 (first, last, email, uid, pwd) VALUES ('$first', '$last', '$email', '$uid', '$hashedPwd');";
                    mysqli_query($conn, $sql);
                    header("Location: ../signup.php?signup=success");
                    exit();
                }
            }
        }
    }

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

?>

我的登录表
    <?php
    include_once '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="Firstname">
                <input type="text" name="last" placeholder="Lastname">
                <input type="text" name="email" placeholder="E-mail">
                <input type="text" name="uid" placeholder="Username">
                <input type="password" name="pwd" placeholder="Password">
                <Button type="submit" name="submit">Sign up</Button>
            </form>

        </div>
    </section>

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

我已将“root”的密码重置为“root”,并确保可以使用该密码登录。如果任何字段为空,则检查错误列表的文档将返回到URL中带有“=空”一词的上一页。无论我在字段中键入什么,都不是将信息推送到数据库中,就是我错误地映射了字段,因此其中一个数据库字段是空的。
任何帮助都将不胜感激。正如我在这篇文章开头所说的,我对这一点非常陌生。你可能会看到一些非常明显和有些愚蠢的东西…你被警告了!我正在创建一个允许用户登录的移动应用程序和网站。登录尝试将引用我的本地主机数据库来确认用户不存在或用户不在使用。
谢谢您!

最佳答案

要检查连接处理,可以在连接尝试后添加此项:

$conn = mysqli_connect( ... );

if ( !$conn ) {
    die( 'Did not connect: ' . mysqli_connect_error() );
}

要在查询后检查处理,可以在查询尝试后添加此选项:
$result = mysqli_query( $conn, $sql );

if (false === $result) {
    die( 'Query error: ' . mysqli_error($conn) );
}

关于mysql - 通过PHP连接MySQL数据库,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/45523920/

10-09 16:21
查看更多