简单的登录脚本无法正常工作

时间:2014-12-02 11:19:29

标签: php sql login pdo fetch

我创建了一个简单的登录脚本,它在某种程度上起作用。所有验证工作正常所以,如果我输入错误的用户名和密码,它会显示错误消息您的用户名或密码错误,但是当我输入正确的用户名和密码时,它不会指示我到users / index.php页面并排序只是重新加载登录页面。

这是我的代码 -

<?php

    session_start();

    $errors = []; 

    $username = isset($_POST['username']) ? $_POST['username'] : null;
    $password = isset($_POST['password']) ? $_POST['password'] : null;

    if(!empty($_POST)) {
    if(empty($username)) {
        $errors[] = "Please enter a username"; 
        echo "<style type=\"text/css\"> #username { background-color:#F5A9A9;border:1px solid #DF0101; } </style>";
    }
    if(empty($password)) {
        $errors[] = "Please enter a password"; 
        echo "<style type=\"text/css\"> #password { background-color:#F5A9A9;border:1px solid #DF0101; } </style>";
    } else {

    if(empty($errors)) {
        $connect = new PDO('mysql:host=localhost;dbname=uacvideos;charset=utf8mb4', 'root', '');
        $connect->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
        if(!$connect) {
                header("Location:"); // ADD ERROR LINK
            }

        $salt = "Thisismysalt";
        $hashedpass = hash('sha512', $password . $salt);

        $result = $connect->query("SELECT COUNT(*) FROM users WHERE username = '$username' AND password = '$hashedpass'");
            if($result->fetchColumn() > 0) {
                    $_SESSION['loggedin'] = 'true';
                    $_SESSION['username'] = $username;
                    header("Location: users/index.php"); // ADD LINK
                } else {
                    $errors[] = "Your username or password is incorrect"; 
                }
            }
        }
    }
?>

1 个答案:

答案 0 :(得分:0)

您必须使用echo来显示错误 示例代码:

echo $errors[] = "Please enter a username";