Как войти после успешной регистрации - PullRequest
0 голосов
/ 27 апреля 2018
<!DOCTYPE HTML>
<html>
<head>
    <style>
        .error {
            color: red;
        }

        .button {
            background-color: #4CAF50;
            border: none;
            color: white;
            padding: 10px 25px;
            text-align: center;
            text-decoration: none;
            display: inline-block;
            font-size: 16px;
            margin: 4px 2px;
            cursor: pointer;
        }

        .div1 {
            background-color: #f2f2f2;
            margin-top: -19px;
            margin-bottom: -25px;
            margin-left: -19px;
        }

        .copy {
            border-radius: 4px;
            padding: 6px 20px;
            border-style: ridge;
        }

        .copy1 {
            border-radius: 4px;
            padding: 6px 28px;
            border-style: ridge;
        }

        .copy2 {
            border-radius: 4px;
            padding: 4px 2px;
        }
    </style>
</head>
<body>
    <?php
    // define variables and set to empty values
    include_once 'connect.php';
    $nameErr = $emailErr = $usernameErr = $passwordErr = $DateOfBirthErr =
        $departmentErr = $ageErr = "";
    $name = $email = $username = $password = $DateOfBirth = $department =
        $age = "";

    if ( isset( $_POST[ 'submit' ] ) ) {
        if ( empty( $_POST[ "name" ] ) ) {
            $nameErr = "Name is required";
        } else {
            $name = test_input( $_POST[ "name" ] );
            // check if name only contains letters and whitespace
            if ( !preg_match( "/^[a-zA-Z ]*$/", $name ) ) {
                $nameErr = "Only letters and white space allowed";
            }
        }

        if ( empty( $_POST[ "email" ] ) ) {
            $emailErr = "Email is required";
        } else {
            $email = test_input( $_POST[ "email" ] );
            // check if e-mail address is well-formed
            if ( !filter_var( $email, FILTER_VALIDATE_EMAIL ) ) {
                $emailErr = "Invalid email format";
            }
        }

        if ( empty( $_POST[ "username" ] ) ) {
            $usernameErr = "Username is required";
        } else {
            $username = test_input( $_POST[ "username" ] );
            // check if name only contains letters and whitespace
            if ( !preg_match( "/^[a-zA-Z ]*$/", $username ) ) {
                $usernameErr = "Only letters and white space allowed";
            }
        }

        if ( empty( $_POST[ "password" ] ) ) {
            $passwordErr = "Password is required";
        } else {
            $password = test_input( $_POST[ "password" ] );
            $hashed_password = password_hash( $password, PASSWORD_DEFAULT );
            // check weather password is alphanumeric
            if ( !preg_match( '/^(?=.*\d)(?=.*[A-Za-z])[0-9A-Za-z!@#$%]{6,}$/',
                    $password ) ) {
                $passwordErr = "Password must be alphanumeric and atleast 6 characters 
       long!";
            }
        }

        if ( empty( $_POST[ "Date_of_birth" ] ) ) {
            $DateOfBirthErr = "Date Of Birth is required";
        } else {
            $DateOfBirth = test_input( $_POST[ "Date_of_birth" ] );
        }

        if ( empty( $_POST[ "department" ] ) ) {
            $departmentErr = "Department is required";
        } else {
            $department = test_input( $_POST[ "department" ] );
        }

        if ( empty( $_POST[ "age" ] ) ) {
            $ageErr = "Age is required";
        } else {
            $age = test_input( $_POST[ "age" ] );
        }

        if ( $nameErr == "" && $emailErr == "" && $usernameErr == "" &&
            $passwordErr == "" ) {
            $check = "SELECT * FROM users WHERE username = '$_POST[username]'";
            $rs = mysqli_query( $mysqli, $check );
            $da = mysqli_fetch_array( $rs, MYSQLI_NUM );
            if ( $da[ 0 ] > 0 ) {
                echo "Username Already in Exists<br/>";
            } else {
                $sql = "INSERT INTO users(`id`,`username`, `password`, `email` , `name` 
      ,   `Date_of_birth` , `department` ,`age`)
             VALUES ('','" . $username . "', '" . $hashed_password . "', '" . $email . "' , 
       '" . $name . "' , '" . $DateOfBirth . "' , '" . $department . "' , '" . $age . "')";

                if ( mysqli_query( $mysqli, $sql ) ) {
                    echo "Registered successfully";
                } else {
                    echo "Error: " . $sql . "<br>" . mysqli_error( $mysqli );
                }
                mysqli_close( $mysqli );
            }
        }

    }

    function test_input( $data ) {
        $data = trim( $data );
        $data = stripslashes( $data );
        $data = htmlspecialchars( $data );
        return $data;
    }
    ?>

    <div style="padding-left: 250px" class="div1">
        <h2 style="color:#009999">Registration Form :</h2>
        <p><span class="error">All fields are required </span>
        </p>
        <form method="post" action="">
            <span style="color:#0099ff">Name: </span>
            <input type="text" name="name" class="copy" style="margin-left: 52px">
            <span class="error">
                <?php echo $nameErr;?>
            </span>
            <br><br>
            <span style="color:#0099ff"> E-mail: </span>
            <input type="text" name="email" class="copy" style="margin-left: 48px">
            <span class="error">
                <?php echo $emailErr;?>
            </span>
            <br><br>
            <span style="color:#0099ff"> Username: </span>
            <input type="text" name="username" class="copy" style="margin- 
         left:26px">
            <span class="error">
                <?php echo $usernameErr;?>
            </span>
            <br><br>
            <span style="color:#0099ff"> Password: </span>
            <input type="password" name="password" class="copy" style="margin- 
       left:30px">
            <span class="error">
                <?php echo $passwordErr;?>
            </span>
            <br><br>
            <span style="color:#0099ff"> Date Of Birth : </span>
            <input type="date" class="copy1" name="Date_of_birth">
            <span class="error">
                <?php echo $DateOfBirthErr;?>
            </span>
            <br><br>
            <span style="color:#0099ff">  Age : </span>
            <input type="number" name="age" class="copy" style="margin-left:62px">
            <span class="error">
                <?php echo $ageErr;?>
            </span>
            <br><br>
            <span style="color:#0099ff">  Department : </span>
            <select name="department" class="copy2" style="margin-left:14px">
                <option value="EE">Electrical & Electronics</option>
                <option value="EC">Electronics & Communication</option>
                <option value="ME">Mechanical</option>
                <option value="CS">Computer Science</option>
                <option value="CV">Civil</option>
                <option value="IS">Information Science</option>
            </select>
            <span class="error">
                <?php echo $departmentErr;?>
            </span>
            <br><br>
            <input type="submit" class="button" name="submit" value="Register">
            <p style="color:black">Already Registered? <a href="login.php">Login</a>.</p>
        </form>
    </div>
</body>
</html>

login.php

<?php
include_once 'connect.php';

session_start();
$error = "";
if ( isset( $_POST[ 'login' ] ) ) {
    // username and password sent from form 

    $username = mysqli_real_escape_string( $mysqli, $_POST[ 'username' ] );
    $password = mysqli_real_escape_string( $mysqli, $_POST[ 'password' ] );

    $sql = "SELECT id FROM users WHERE username = '$username' and password = 
       '$password'";
    $resu = mysqli_query( $mysqli, $sql );
    $rst = mysqli_fetch_array( $resu, MYSQLI_ASSOC );
    $count = mysqli_num_rows( $resu );

    // If result matched $myusername and $mypassword, table row must be 1 row

    if ( $count == 1 ) {
        $_SESSION[ 'login_user' ] = $username;

        header( "location: index.php" );

    } else {
        $error = "Your Login Name or Password is invalid";
    }

}
if ( isset( $_SESSION[ 'login_user' ] ) ) {
    header( 'location:index.php' );
}
?>

<html>
<head>
    <title>Login Form</title>
    <style>
        body {
            font-family: Arial, Helvetica, sans-serif;
        }

        .frmlg {
            background-color: #99ffff;
            text-align: center;
            margin-top: 10px;
        }

        .xyz {
            margin-top: 30px;
            margin-bottom: 30px;
        }

        .container {
            padding: 16px;
        }

        button {
            background-color: #4CAF50;
            color: white;
            padding: 12px 15px;
            border: none;
            cursor: pointer;
            width: 30%;
        }

        input[type=text],
        input[type=password] {
            width: 50%;
            padding: 12px 20px;
            margin: 8px 0;
            display: inline-block;
            border: 1px solid #ccc;
            box-sizing: border-box;
        }
    </style>
</head>

<body>
    <div class="container frmlg">
        <form method="post" action="" enctype="multipart/form-data">
            <h4 style="text-align:center">Login Page</h4>
            <div class="container xyz">
                <label for="uname"><b>Username :</b></label>
                <input type="text" placeholder="Enter Username" name="username" required>
                <br><br>
                <label for="psw"><b>Password :</b></label>
                <input type="password" placeholder="Enter Password" name="password" required>
                <br><br>
                <button type="submit" name="login" value="Submit">Login</button><br/><br/>
            </div>
        </form>
        <div style="font-size:11px; color:#cc0000; margin-top:10px">
            <?php 
         echo $error; ?>
        </div>
    </div>
</body>

</html>

logout.php

<?php
session_start();

if ( session_destroy() ) {
    header( "Location: login.php" );
}
?>

session.php

<?php
include_once 'connect.php';
session_start();

$user_check = $_SESSION[ 'login_user' ];

$ses_sql = mysqli_query( $mysqli, "select username from users where 
       username = 
        '$user_check' " );

$row = mysqli_fetch_array( $ses_sql, MYSQLI_ASSOC );

$login_session = $row[ 'username' ];

if ( !isset( $_SESSION[ 'login_user' ] ) ) {
    header( "location:login.php" );
}
?>

welcome.php

<?php include_once 'session.php'; ?>
<html>
<head>
<title>Welcome </title>
</head>
<body>
    <h1>Welcome <?php echo $login_session; ?></h1> 
    <h2><a href = "logout.php">Sign Out</a></h2>
</body>
</html>

connect.php

<?php
$databaseHost = 'localhost';
$databaseName = 'amith';
$databaseUsername = 'root';
$databasePassword = '';

$mysqli = mysqli_connect($databaseHost, $databaseUsername, 
$databasePassword, $databaseName);
?>

Я создаю простую форму регистрации php и форму авторизации. Я заполнил регистрационную форму, и она работает хорошо, но теперь после отправки регистрационной формы, когда они пытаются войти на свою страницу, она должна войти в систему, но я не могу получить желаемый результат, может кто-нибудь подсказать мне, какие изменения мне следует выполните приведенный выше код, чтобы получить мой результат.

ПРИМЕЧАНИЕ: Я не добавил свой регистрационный файл, но я сохранил этот файл как index.php

Ответы [ 2 ]

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

обновить часть запроса до этой

if (mysqli_query($mysqli, $sql)) {
    echo "Registered successfully";
    $_SESSION['login_user'] = $username; //sets user session to the username
    header('Location:welcome.php'); //redirects the user to the user home page
} else {
    echo "Error: " . $sql . "<br>" . mysqli_error($mysqli);
 }
0 голосов
/ 27 апреля 2018

добавьте этот код после успешной регистрации кода

$_SESSION['login_user'] = $username;

и $username - это опубликованное имя пользователя через форму

, а затем заголовок типа

header('Location:welcome.php');
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...