где я иду не так, где мой код не повторяет определенные части? - PullRequest
0 голосов
/ 30 апреля 2018

Где я ошибаюсь, чтобы получить мой код для отображения сообщения об ошибке, такого как «вы не заполнили все поля» или «имя пользователя / пароль взято»? У меня работает логин, и все в порядке, и на данный момент ошибка отображается в строке заголовка, но я также хочу, чтобы она отображалась в форме.

<?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");
        echo "you did not fill in all the fields";
        exit();
    } else {
        //Check if input char 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");
                    echo "the username you have entered is taken";
                    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();
}

1 Ответ

0 голосов
/ 30 апреля 2018

Это потому, что вы сначала перенаправляете страницу, а затем показываете сообщение, которое не имеет смысла. Если вы хотите показать сообщение, возможно, вы можете использовать этот способ:

if(empty($first) || empty($last) || empty($email) || empty($uid) || empty($pwd)) {

    $msg = "you did not fill in all the fields";
    header("Location: ../signup.php?signup=empty&errmsg=$msg");
    exit();
}

А на странице signup.php используйте что-то вроде

if($errmsg)
  echo $errmsg;
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...