Jak stworzyć system logowania PHP dla swojej witryny?
Czy chcesz zintegrować system logowania w PHP? W tym artykule pokażę, jak wykonać podstawowy proces logowania do PHP. Stworzymy formularz logowania, zweryfikujemy poświadczenia i przekierujemy użytkownika na stronę konta. Dodałbym również kod do wylogowania użytkownika. Dodatkowo wyświetlimy komunikaty o błędach, jeśli zostaną wprowadzone nieprawidłowe dane uwierzytelniające.
Na potrzeby samouczka zakładam, że do przechowywania hasła używasz skrótu „md5". Napisałbym kod, biorąc pod uwagę skrót md5 ciągu. Być może używasz innego algorytmu. W takim przypadku musisz zmienić zapytanie zgodnie z algorytmem.
Aby zintegrować przepływ logowania, potrzebujemy tabeli bazy danych, która przechowuje dane użytkownika. Na podstawie tej tabeli sprawdzamy, czy użytkownik wprowadził prawidłowe dane uwierzytelniające, czy nie. Jeśli poświadczenia użytkownika są poprawne, tylko oni powinni mieć dostęp do zabezpieczonych stron.
W moim przypadku stworzyłem tabelę „users” i dodałem kilka fikcyjnych wpisów. Dodałem również kolumnę „status”, która posłuży do sprawdzenia, czy konto jest aktywne, czy nie. Ta kolumna ma typ danych ENUM z wartościami 0 i 1.
- 1: Konto jest aktywne
- 0: Konto nie jest aktywne
Utwórz formularz logowania
Na początek utwórzmy formularz logowania, w którym użytkownicy mogą wprowadzać swoje poświadczenia. Aby zbudować formularz logowania używam frameworka Bootstrap. Mój index.php
plik zawiera poniższy kod.
<!DOCTYPE html>
<html>
<head>
<title>Login Form</title>
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css" />
</head>
<body>
<div class="container">
<div class="row">
<div class="col-md-6">
<h3>Login Form</h3>
<?php if(!empty($error_message)) { ?>
<div class="alert alert-danger"><?php echo $error_message; ?></div>
<?php } ?>
<form method="post">
<div class="form-group">
<label for="exampleInputEmail1">Email address</label>
<input type="email" class="form-control" id="exampleInputEmail1" name="email" placeholder="Email" required />
</div>
<div class="form-group">
<label for="exampleInputPassword1">Password</label>
<input type="password" class="form-control" id="exampleInputPassword1" name="password" placeholder="Password" required />
</div>
<button type="submit" name="submit" class="btn btn-primary">Submit</button>
</form>
</div>
</div>
</div>
</body>
</html>
Powyższy kod wyświetli formularz logowania, jak pokazano na poniższym zrzucie ekranu.
Dodałem zmienną $error_message
w kodzie, która wyświetli błędy logowania.
Kod PHP do weryfikacji poświadczeń użytkowników
Jesteś gotowy z formularzem logowania i tabelą bazy danych. Następnie, przesyłając formularz, musimy napisać kod PHP, który porównuje dane uwierzytelniające użytkownika z rekordami bazy danych. Jeśli dane są poprawne, zaloguj się do systemu i przekieruj na myaccount.php
stronę.
Utwórz config.php
plik i dodaj kod połączenia z bazą danych.
<?php
$conn = new mysqli('DB_HOST', 'DB_USER', 'DB_PASSWORD', 'DB_NAME');
if ($conn->connect_errno) {
echo "Error: ". $conn->connect_error;
}
?>
Zastąp symbole zastępcze rzeczywistymi wartościami.
Teraz w index.php
pliku przed rozpoczęciem tagu html dodaj poniższy kod.
<?php
session_start();
require_once('config.php');
//if user is logged in redirect to myaccount page
if (isset($_SESSION['id'])) {
header('Location: myaccount.php');
}
$error_message = '';
if (isset($_POST['submit'])) {
extract($_POST);
if (!empty($email) && !empty($password)) {
$sql = "SELECT id, status FROM users WHERE email = '".$conn->real_escape_string($email)."' AND password = '".md5($conn->real_escape_string($password))."'";
$result = $conn->query($sql);
if ($result->num_rows > 0) {
$row = $result->fetch_assoc();
if($row['status']) {
$_SESSION['id'] = $row['id'];
header('Location: myaccount.php');
} else {
$error_message = 'Your account is not active yet.';
}
} else {
$error_message = 'Incorrect email or password.';
}
} else {
$error_message = 'Please enter email and password.';
}
}
?>
Tutaj w kodzie, sprawdzając hasło, użyłem metody PHP md5 zakładając, że zapisałeś hasło za pomocą tego algorytmu.
Kod wylogowania
Kolejna część to dodanie kodu do wylogowania użytkownika. W tym celu utwórz myaccount.php
plik. Jeszcze jedna rzecz potrzebna do obsługi, która tylko zalogowani użytkownicy powinni uzyskać dostęp do tej strony.
mojekonto.php
<?php
session_start();
if (isset($_GET['action']) && ('logout' == $_GET['action'])) {
unset($_SESSION['id']);
}
if (isset($_SESSION['id'])) {
?>
<h3>Welcome User! <a href="?action=logout">Logout</a></h3>
<?php
} else { //redirect to login page
header('Location: index.php');
}
?>
Korzystając z sesji PHP zastanawiamy się, czy dać dostęp do tej strony, czy nie. Jeśli sesja nie jest ustawiona, przekieruj użytkownika na stronę logowania.
Mam nadzieję, że rozumiesz podstawy budowania systemu logowania w PHP. Podziel się swoimi przemyśleniami i sugestiami w sekcji komentarzy poniżej.
Powiązane artykuły
- System rejestracji i logowania użytkownika w Laravel
- Zaloguj się przez Google w Laravel za pomocą Laravel Socialite
- Jak stworzyć system rejestracji PHP