Gambar 1. Form login pada tutorial ini |
Gambar 2. Form selamat datang dan logout |
Jika pada tutorial sebelumnya (Untuk Apa dan Bagimana Menggunakan $_SESSION ( Tutorial $_SESSION 1 )) mambahas apa dan bagaimana cara menggunakan $_SESSION. Pada kali tutorial ini akan membahas login dan logout sebagai contoh penggunaan $_SESSION.
1. CSS bootstrap hanya optional, tanpa bootstrap sistem tetap berjalan.
source code 1 (formlogin.html) :
<html> <head> <link href="dist/css/bootstrap.min.css?v=<?php time();?>" rel="stylesheet"> </head> <body> <div class="container"> <div style="border: 5px solid green; padding:5px; margin:auto; width:300px;" > <form action="autentifikasi.php" method="POST"> Username: <input type="text" class="form-control" name="username"></input><br/> Password: <input type="password" class="form-control" name="password"></input><br/> <input class="btn btn-success form-control" type="submit" value="login"> </form> </div> </div> </body> </html>
2. autentifikasi.php digunakan untuk menyimpan status komputer clinet ($_SESSION["status"] = "login";). Status akan bernilai login bila username dan password ada dalam database.
source code 2 (autentifikasi.php):
<?php if(isset($_POST['username'])&isset($_POST['password'])){ $username=$_POST["username"]; $password=$_POST["password"]; $conn = mysql_connect("localhost", "root", ""); if ($conn) { mysql_select_db("dbblog"); $sql="SELECT * FROM user1 WHERE username='".$username."' and password='".$password."'"; $retval = mysql_query($sql , $conn ); $num_rows = mysql_num_rows( $retval); //jika password n username ditemukan jumlah baris yang ditemukan //berarti 1 if($num_rows==1){ session_start(); $_SESSION["status"] = "login"; header("Location: http://localhost:8012/contohsession/halamandepan.php"); die(); } else{ header("Location: http://localhost:8012/contohsession/formlogin.html"); die(); } } else echo "fail"; } ?>
3. Jika status tidak bernilai login maka dilempar atau dikembalikan ke formlogin.html. Button logout akan diarahkan ke url logoutautentifikasi.php.
source code 3 (halamandepan.php):
<?php session_start(); if($_SESSION["status"]!="login"){ header("Location: http://localhost:8012/contohsession/formlogin.html"); } ?> <html> <head> <link href="dist/css/bootstrap.min.css?v=<?=time();?>" rel="stylesheet"> </head> <body> <div class="container"> <div style="border: 5px solid green; padding:5px; margin:auto; width:300px;" > <form action="logoutautentifikasi.php" method="POST"> <center>SELAMAT DATANG</center> <center>DI TUTORIAL $_SESSION 2</center><br/> <input class="btn btn-success form-control" type="submit" value="logout"> </form> </div> </div> </body> </html>
4. Status login dihapus kemudian diarahkan ke formlogin.html.
source code 4 (logoutautentifikasi.php):
<?php session_start(); unset($_SESSION['status']); header("Location: http://localhost:8012/contohsession/formlogin.html"); ?>
Trimakasih..
Kalau untuk pemberitahuan data tidak masuk ke data gimana gan
ReplyDeletecara yang gampang
Deletedi autentifikasi.php
ini
else{
header("Location: http://localhost:8012/contohsession/formlogin.html");
die();
}
jadi
else{
echo"<script> alert('maaf, username dan password tidak tepat');
window.location = 'http://localhost:8012/contohsession/formlogin.html'; </script>";
}
manteb ini bang, informatif banget
ReplyDeletesolder uap