提交输入正在向数据库登录检查器发送空答案

submit input is sending empty answer to a db login checker

我正在使用 PHP + MySQL 构建一个简单的登录页面。 使用输入发送用户名和密码并在 URL 上获取状态,但每次我单击 submit 时,显然没有任何内容会在 db 上进行登录数据检查。 我的 index.php 代码:

<?php session_start(); ?>
<!doctype html>
<html lang="en">
<head>
    <!-- Required meta tags -->
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
    <!-- Bootstrap CSS -->
    <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css"
          integrity="sha384-MCw98/SFnGE8fJT3GXwEOngsV7Zt27NXFoaoApmYm81iuXoPkFOJwJ8ERdknLPMO" crossorigin="anonymous">
    <link rel="stylesheet" type="text/css" href="style.css">
    <title>Integração transporte</title>
</head>
<body>
<div class="login-page">
    <div class="form">
        <p>Integração Transporte</p>
        <br>
        <form class="login-form" action="includes/login.inc.php" method="POST">
            <input type="text" name="uid" placeholder="nome de usuário ou e-mail"/>
            <input type="password" name="pwd" placeholder="senha"/>
            <button type="submit" name="submit">Login</button>
        </form>
    </div>
</div>
<!-- Optional JavaScript -->
<!-- jQuery first, then Popper.js, then Bootstrap JS -->
<script src="https://code.jquery.com/jquery-3.3.1.slim.min.js"
        integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo"
        crossorigin="anonymous"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.3/umd/popper.min.js"
        integrity="sha384-ZMP7rVo3mIykV+2+9J3UJ46jBk0WLaUAdn689aCwoqbBJiSnjAK/l8WvCWPIPm49"
        crossorigin="anonymous"></script>
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/js/bootstrap.min.js"
        integrity="sha384-ChfqqxuZUCnJSK3+MXmPNIyE6ZbWh2IMqE241rYiqJxyMiZ6OW/JmZQ5stwEULTy"
        crossorigin="anonymous"></script>
</body>
</html>

我的 login.inc.php 文件:

<?php

session_start();


if (isset($_POST['submit'])) {
    echo error_reporting(-1);

    include 'dbh.inc.php';

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

    //Errors
    //Check if inputs are empty
    if (empty($uid) || empty($pwd)) {
        header("Location: ../index.php?login=empty");
        exit();
    } else {
        $sql = "SELECT * FROM users WHERE user_uid = '$uid' OR user_email = '$uid'";
        $result = mysqli_query($conn, $sql);
        $resultCheck = mysqli_num_rows($result);
        if ($resultCheck < 1) {
            header("Location: ../index.php?login=error");
            exit();
        } else {
            if ($row = mysqli_fetch_assoc($result)) {

                $hashedPwdCheck = password_verify($pwd, $row['user_pwd']);
                if ($hashedPwdCheck == false) {
                    header("Location: ../index.php?login=empty");
                    exit();
                } elseif ($hashedPwdCheck == true) {
                    //Login the user here
                    $_SESSION['u_id'] = $row['user_id'];
                    $_SESSION['u_first'] = $row['user_first'];
                    $_SESSION['u_last'] = $row['user_last'];
                    $_SESSION['u_email'] = $row['user_email'];
                    $_SESSION['u_uid'] = $row['user_uid'];


                    header("Location: ../index.php?login=success");
                    exit();
                }
            }
        }
    }

} else {
    header("Location: ../index.php?login=error");
    exit();
}

我的dbh.inc.php(数据库连接)文件:

<?php
/**
 * Created by PhpStorm.
 * User: root
 * Date: 17/08/18
 * Time: 18:43
 */
#Dados para a conexão com o banco de dados
$dbServername = "localhost";
$dbUsername = "root";
$dbPassword = "Lucas@09";
$dbName = "dbtest";

#Executa a conexão com o MySQL
$conn = mysqli_connect($dbServername, $dbUsername, $dbPassword, $dbName);

我的数据库:

如何解决我的问题?我只是不知道我现在需要做什么...我很笨

我已经检查了你的代码。

$hashedPwdCheck = password_verify($pwd, $row['user_pwd']);

$hashedPwdCheck 将 return 为假。我们不散列我们的密码 $row['user_pwd'].

我们需要散列我们的密码,例如:

echo password_hash("root", PASSWORD_DEFAULT);
//y$UIy0lTtvLV.5GZ2rrQGxUeJEaizxTm891mhpCqj5BFJQaVbVhnsdy 

http://php.net/manual/en/function.password-verify.php