Cara Membuat Form Registrasi dan Login dengan PHP OOP dan HTML

Artikel berikut membahas mengenai Cara Membuat Form Registrasi dan Login dengan PHP OOP dan HTML

Desain Halaman

Berikut adalah halaman Login dan Registrasi yang akan kita buat :

Halaman Login 

Desain Halaman Login - contohapps
Desain Halaman Login

Halaman Registrasi

Halaman Registrasi - contohapps
Desain Halaman Registrasi


Struktur File

Struktur file yang akan kita buat terdiri dari berikut :
  1. Auth.php, file ini berisi script untuk melakukan login, pengecekan data login dan mengambil data user yang sudah registrasi.
  2. config.php, file ini digunakan untuk setting koneksi ke database
  3. index.php, merupakan halaman yang akan ditampilkan ketika berhasil login
  4. login.php, rancangan halaman login
  5. logout.php, berisi script untuk melakukan logout atau keluar dari program
  6. register.php,merupakan rancangan halaman registrasi.
  7. styles.css, adalah file css yang digunakan untuk mempercantik tampilan.
Pastikan file tersebut sudah dibuat terlebih dahulu agar struktur file yang akan digunakan tidak keliru dan jangan lupa untuk mengecek penulisan nama file (huruf besar dan kecil) harus sama dengan yang sudah dituliskan diatas. berikut adalah struktur file yang akan kita buat dalam visual studio code :
Cara Membuat Form Registrasi dan Login dengan PHP OOP dan HTML
Struktur File

Langkah-Langkah Pembuatan Aplikasi

  • Membuat Database dan Table
  • Membuat Koneksi
  • Membuat Script Auth.php
  • Membuat Halaman Login
  • Membuat Halaman Registrasi
  • Membuat Script Logout
  • Membuat Halaman Index

Membuat Database dan Table

Buatlah sebuah database baru dengan nama db_pos, kemudian masukan script berikut pada phpmyadmin untuk membuat tabel users :
CREATE TABLE `users` (
  `id` int(11) NOT NULL,
  `fullname` varchar(255) NOT NULL,
  `username` varchar(255) NOT NULL,
  `password` varchar(255) NOT NULL,
  `email` varchar(255) NOT NULL,
  `gender` enum('male','female') NOT NULL,
  `religion` varchar(255) NOT NULL,
  `biografi` text NOT NULL,
  `created_at` timestamp NOT NULL DEFAULT current_timestamp()
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;

Berikut adalah tampilan Script diatas pada phpmyadmin :

Cara Membuat Form Registrasi dan Login dengan PHP OOP dan HTML

Sebelum mengeksekusi script diatas pastikan db_pos telah aktif kemudian klik menu SQL dan masukan Script tersebut kemudian tekan tombol GO

Membuat Koneksi

Untuk membuat Koneksi ke database kita perlu memasukan script berkut pada file config.php :
<?php

try {
    $con = new PDO('mysql:host=localhost;dbname=db_pos', 'root', '', array(PDO::ATTR_PERSISTENT => true));
} catch (PDOException $e) {
    echo $e->getMessage();
}

include_once 'Auth.php';

$user = new Auth($con);

Membuat Script Auth

Masukan script kedalam file Auth.php sebagai berikut :
<?php

/**
 * Class Auth untuk melakukan login dan registrasi user baru
 */
class Auth
{
    /**
     * @var
     * Menyimpan Koneksi database
     */
    private $db;

    /**
     * @var
     * Menyimpan Error Message
     */
    private $error;

    /**
     * @param $db_conn
     * Contructor untuk class Auth, membutuhkan satu parameter yaitu koneksi ke database
     */
    public function __construct($db_conn)
    {
        $this->db = $db_conn;

        // Mulai session
        session_start();
    }
    /**
     * @param $name
     * @param $email
     * @param $password
     * @param $gender
     * @param $religion
     * @param $biografi
     * @return bool
     *
     * Registrasi User baru
     */
    public function register($fullname, $username, $password, $email, $gender, $religion, $biografi)
    {
        try {
            // buat hash dari password yang dimasukkan
            $hashPasswd = password_hash($password, PASSWORD_DEFAULT);

            //Masukkan user baru ke database
            $stmt = $this->db->prepare("INSERT INTO users(fullname, username, password,email,gender,religion,biografi) VALUES(:fullname,:username,:pass,:email,:gender,:religion,:biografi)");
            $stmt->bindParam(":fullname", $fullname);
            $stmt->bindParam(":username", $username);
            $stmt->bindParam(":pass", $hashPasswd);
            $stmt->bindParam(":email", $email);
            $stmt->bindParam(":gender", $gender);
            $stmt->bindParam(":religion", $religion);
            $stmt->bindParam(":biografi", $biografi);

            $stmt->execute();

            return true;
        } catch (PDOException $e) {
            // Jika terjadi error

            if ($e->errorInfo[0] == 23000) {
                //errorInfor[0] berisi informasi error tentang query sql yg baru dijalankan
                //23000 adalah kode error ketika ada data yg sama pada kolom yg di set unique
                $this->error = "Email sudah digunakan!";

                return false;
            } else {
                echo $e->getMessage();

                return false;
            }
        }
    }

    /**
     * @param $email
     * @param $password
     * @return bool
     *
     * fungsi login user
     */
    public function login($email, $password)
    {
        try {
            // Ambil data dari database
            $stmt = $this->db->prepare("SELECT * FROM users WHERE email = :email");
            $stmt->bindParam(":email", $email);
            $stmt->execute();
            $data = $stmt->fetch();

            // Jika jumlah baris > 0
            if ($stmt->rowCount() > 0) {
                // jika password yang dimasukkan sesuai dengan yg ada di database
                if (password_verify($password, $data['password'])) {
                    $_SESSION['user_session'] = $data['id'];

                    return true;
                } else {
                    $this->error = "Email atau Password Salah";

                    return false;
                }
            } else {
                $this->error = "Email atau Password Salah";

                return false;
            }
        } catch (PDOException $e) {
            echo $e->getMessage();

            return false;
        }
    }

    /**
     * @return true|void
     *
     * fungsi cek login user
     */
    public function isLoggedIn()
    {
        // Apakah user_session sudah ada di session

        if (isset($_SESSION['user_session'])) {
            return true;
        }
    }

    /**
     * @return false
     *
     * fungsi ambil data user yang sudah login
     */
    public function getUser()
    {
        // Cek apakah sudah login
        if (!$this->isLoggedIn()) {
            return false;
        }

        try {
            // Ambil data user dari database
            $stmt = $this->db->prepare("SELECT * FROM users WHERE id = :id");
            $stmt->bindParam(":id", $_SESSION['user_session']);
            $stmt->execute();

            return $stmt->fetch();
        } catch (PDOException $e) {
            echo $e->getMessage();

            return false;
        }
    }

    /**
     * @return true
     *
     * fungsi Logout user
     */
    public function logout()
    {
        // Hapus session
        session_destroy();
        // Hapus user_session
        unset($_SESSION['user_session']);

        return true;
    }

    /**
     * @return mixed
     *
     * fungsi ambil error terakhir yg disimpan di variable error
     */
    public function getLastError()
    {
        return $this->error;
    }
}

Membuat Script Halaman Login

<?php
// Lampirkan config
require_once "config.php";

// Cek status login user
if ($user->isLoggedIn()) {
    header("location: index.php"); //redirect ke index
}

//jika ada data yg dikirim
if (isset($_POST['kirim'])) {
    $email = $_POST['email'];

    $password = $_POST['password'];

    // Proses login user
    if ($user->login($email, $password)) {
        header("location: index.php");
    } else {
        // Jika login gagal, ambil pesan error
        $error = $user->getLastError();
    }
}

?>
<!DOCTYPE html>
<html>

<head>
    <meta charset="utf-8">
    <title>Login</title>
    <link rel="stylesheet" href="styles.css" media="screen" title="no title" charset="utf-8">
</head>

<body>
    <div class="login-page">
        <div class="form">
            <form class="login-form" method="post"> <?php if (isset($error)) : ?> <div class="error"> <?php echo $error ?> </div> <?php endif; ?> <input type="email" name="email" placeholder="email" required /> <input type="password" name="password" placeholder="password" required /> <button type="submit" name="kirim">login</button>
                <p class="message">Not registered? <a href="register.php">Create an account</a></p>
            </form>
        </div>
    </div>
</body>

</html>

Membuat Halaman Register

<?php

// Lampirkan config
require_once "config.php";
// Cek status login user
if ($user->isLoggedIn()) {
  header("location: index.php"); //Redirect ke index
}

//Cek adanya data yang dikirim
if (isset($_POST['kirim'])) {
  $fullname = $_POST['fullname'];
  $username = $_POST['username'];
  $password = $_POST['password'];
  $email = $_POST['email'];
  $gender = $_POST['gender'];
  $religion = $_POST['religion'];
  $biografi = $_POST['biografi'];

  // Registrasi user baru
  if ($user->register($fullname, $username,  $password, $email, $gender, $religion, $biografi)) {
    // Jika berhasil set variable success ke true
    $success = true;
  } else {
    // Jika gagal, ambil pesan error
    $error = $user->getLastError();
  }
}

?>

<!DOCTYPE html>
<html>

<head>
  <meta charset="utf-8">
  <title>Registration</title>
  <link rel="stylesheet" href="styles.css" media="screen" title="no title" charset="utf-8">
  <title>User Registration</title>
</head>

<body>
  <div class="login-page">
    <div class="form">
      <h2>User Registration</h2>
      <form action="" method="post">
        <?php if (isset($error)) : ?>
          <div class="error">
            <?php echo $error ?>
          </div>
        <?php endif; ?>
        <?php if (isset($success)) : ?>
          <div class="success">
            Berhasil Registrasi. Silakan <a href="login.php">login</a>.
          </div>
        <?php endif; ?>
        <input type="text" name="fullname" id="fullname" placeholder="Fullname" required>
        <input type="text" name="username" id="username" placeholder="Username" required>
        <input type="password" name="password" id="password" placeholder="Password" required>
        <input type="email" name="email" id="email" placeholder="Email" required>
        <label class="gender">Gender : </label>
        <label class="container">Male
          <input type="radio" name="gender" value="male" checked required />
          <span class="checkmark"></span>
        </label>
        <label class="gender"></label>
        <label class="container">Female
          <input type="radio" name="gender" value="female" required Radio />
          <span class="checkmark"></span>
        </label>
        <select name="religion" id="religion">
          <option value="">Select</option>
          <option value="Islam">Islam</option>
          <option value="Christian">Christian</option>
          <option value="Hindu">Hindu</option>
          <option value="Buddhist">Buddhist</option>
        </select>
        <textarea name="biografi" id="biografi" placeholder="Biografi" required></textarea>
        <button type="submit" name="kirim">create</button>
      </form>
    </div>
  </div>
</body>

</html>

Membuat Script Logout

<?php  

// Lampirkan config  
require_once "config.php";  

// Logout! hapus session user  
$user->logout();  

// Redirect ke login  
header('location: login.php');

Membuat Halaman Index

<?php  

// Lampirkan config  
require_once "config.php";  

// Cek status login user  
if (!$user->isLoggedIn()) {  
    header("location: login.php"); //Redirect ke halaman login  
}  

// Ambil data user saat ini  
$currentUser = $user->getUser();  
?>  

<!DOCTYPE html>  
<html>  
<head>  
    <meta charset="utf-8">  
    <title>Home</title>  
    <link rel="stylesheet" href="styles.css" media="screen" title="no title" charset="utf-8">  
</head>  
<body>  
<div class="container">  
    <div class="info">  
        <h1>Selamat datang <?php echo $currentUser['username'] ?></h1>  
    </div>  
    <a href="logout.php">  
        <button type="button">Logout</button>  
    </a></div>  
</body>  
</html> 

Membuat File CSS

body {

    background: #2ed1b6;
    /* fallback for old browsers */

    background: -webkit-linear-gradient(right, #2ed1b6, #06af93);
    background: -moz-linear-gradient(right, #2ed1b6, #06af93);
    background: -o-linear-gradient(right, #2ed1b6, #06af93);
    background: linear-gradient(to left, #2ed1b6, #06af93);
    font-family: "Roboto", sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.login-page {
    width: 360px;
    padding: 8% 0 0;
    margin: auto;
}

.form {
    position: relative;
    z-index: 1;
    background: #FFFFFF;
    max-width: 360px;
    margin: 0 auto 100px;
    padding: 45px;

    box-shadow: 0 0 20px 0 rgba(0, 0, 0, 0.2), 0 5px 5px 0 rgba(0, 0, 0, 0.24);
}

.form .error {
    color: #FFFFFF;
    background: #ef3b3a;
    border: 0;
    margin: 0 0 15px;
    padding: 15px;
}

.form .success {
    color: #FFFFFF;
    background: #30A2A0;
    border: 0;
    margin: 0 0 15px;
    padding: 15px;
}

.form input,
textarea,
select {
    font-family: "Roboto", sans-serif;
    outline: 0;
    background: #f2f2f2;
    width: 100%;
    border: 0;
    margin: 0 0 15px;
    padding: 15px;
    box-sizing: border-box;
    font-size: 14px;
}

button {
    font-family: "Roboto", sans-serif;
    text-transform: uppercase;
    outline: 0;
    background: #4CAF50;
    width: 100%;
    border: 0;
    padding: 15px;
    color: #FFFFFF;
    font-size: 14px;
    -webkit-transition: all 0.3 ease;
    transition: all 0.3 ease;
    cursor: pointer;
}

button:hover,
button:active,
button:focus {
    background: #43A047;
}

.form .message {
    margin: 15px 0 0;
    color: #b3b3b3;
    font-size: 12px;
}

.form .message a {
    color: #4CAF50;
    text-decoration: none;
}

.gender {
    display: block;
    margin-bottom: 12px;

}

.container {
    position: relative;
    z-index: 1;
    max-width: 300px;
    margin: 0 auto;
    display: block;
    padding-left: 35px;
    margin-bottom: 12px;
    cursor: pointer;

}

.container:before,
.container:after {
    content: "";
    display: block;
    clear: both;
}

.container .info {
    margin: 50px auto;
    text-align: center;
}

.container .info h1 {
    margin: 0 0 15px;
    padding: 0;
    font-size: 36px;
    font-weight: 300;
    color: #1a1a1a;
}

.container .info span {
    color: #4d4d4d;
    font-size: 12px;
}

.container .info span a {
    color: #000000;
    text-decoration: none;
}

.container .info span .fa {
    color: #EF3B3A;
}


/* Hide the browser's default radio button */
.container input {
    position: absolute;
    opacity: 0;
    cursor: pointer;
}

/* Create a custom radio button */
.checkmark {
    position: absolute;
    top: 0;
    left: 0;
    height: 25px;
    width: 25px;
    background-color: #eee;
    border-radius: 50%;
}

/* On mouse-over, add a grey background color */
.container:hover input~.checkmark {
    background-color: #ccc;
}

/* When the radio button is checked, add a blue background */
.container input:checked~.checkmark {
    background-color: #2196F3;
}

/* Create the indicator (the dot/circle - hidden when not checked) */
.checkmark:after {
    content: "";
    position: absolute;
    display: none;
}

/* Show the indicator (dot/circle) when checked */
.container input:checked~.checkmark:after {
    display: block;
}

/* Style the indicator (dot/circle) */
.container .checkmark:after {
    top: 9px;
    left: 9px;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: white;
}
Jika semuanya sudah selesai silahkan anda akse url berikut : http://localhost/pos/login.php jangan lupa untuk mengakatifkan xampp terlebih, jika semuanya dibuat dengan benar seharusnya muncul tampilan seperti diatas, uji program anda dengan cara melakukan registrasi terlebih dahulu kemudian lakukan login.