Tutorial PHP Supaya User Hanya Bisa Input Sekali Dalam Sehari

Dalam tutorial kali ini saya akan membahas bagaimana cara agar user hanya bisa input sekali dalam sehari dengan contoh kasus disini misalnya adalah pada sistem absensi online.

Pada sistem absensi online poin penting yang mungkin perlu dipenuhi diantaranya :

  • User hanya bisa melakukan absensi masuk sekali dalam sehari
  • Kemudian user yang akan melakukan absensi keluar perlu melakukan absensi masuk terlebih dahulu dan atau user juga hanya bisa melakukan absensi keluar sekali dalam sehari
  • Selanjutnya mungkin akan ada properti – properti lain terkait dengan data yang dibutuhkan/dikumpulkan seperti hari, tanggal, jam dan foto yang digunakan untuk masuk, dan tentu saja akan ini nanti akan ada dalam bentuk desain database sesuai dengan kebutuhan.
Perlu dicatat bahwa disini saya hanya akan memberikan poin pentingnya saja dengan memberikan beberapa contoh rangkaian kode yang mungkin bisa di implementasikan pada sistem yang sedang Anda buat.

Desain Database

Data absen tentu akan ditampung pada sebuah database, misalnya saja disini Saya membuat struktur tabelnya seperti berikut :

desai database untuk absensi

Point penting pada desain database diatas adalah terletak pada id_absen, uid dan waktu/tanggal. Uid adalah bagian kolom yang katakan saja disini untuk menampung id user yang aktif pada session, lalu uid tersebut akan digunakan sebagai parameter untuk melakukan pengecekan berdasarkan tanggal/waktu saat ini. Sehingga nanti akan ada bentuk query untuk mengecek data seperti berikut :




  1. SELECT CURRENT_DATE() FROM absen WHERE uid=uid
    Mengecek apakah user pada hari ini sudah melakukan absen, jika belum eksekusi query yang digunakan adalah INSERT, atau bisa saja querynya seperti : select * from absen where tgl_masuk=current_date() AND uid=uid. Intinya kita cek tanggal hari ini dan apakah ada user yang input pada tanggal tersebut
  2. SELECT * FROM absen WHERE tgl_keluar=CURRENT_DATE() AND uid=uid
    Inti poin ini masih sama seperti poin yang pertama, mengecek apakah ada tanggal keluar pada hari ini yang dilakukan oleh user yang aktif.
    Atau jika misal Anda tidak ingin mendefinisikan tgl_keluar Anda bisa melakukan query berdasarkan jam_keluar. Misalnya seperti berikut :

    SELECT * FROM absen WHERE jam_keluar IS NULL AND uid=uid

    Maksud query diatas adalah mengecek apakah ada jam keluar yang kosong berdasarkan uid aktif. Tapi masalhanya jika menggunakan query tersebut adalah ketika user lupa melakukan jam keluar pada tanggal tertentu, maka query akan menampilkan 2 data null. Jadi kita mungkin membuthkan parameter tgl_keluar pada tabel

  3. SELECT id_absen FROM absen WHERE tgl_masuk=CURRENT_DATE() AND uid='$user'
    Query selanjutnya pada saat akan melakukan absen keluar tentu disini eksekusi akhir query setelah pengecekan bukan INSERT, melainkan UPDATE, maka kita perlu mengecek dan mendapatkan sebuah id_absen berdasarkan tanggal masuk hari ini dan user yang sedang aktif. Selanjutnya id absen itu yang akan digunakan untuk parameter UPDATE.
Contoh Kode

Karena disini saya akan mencontohkan secara sederhana maka hanya akan sebatas bagaimana cara mencegah user agar hanya bisa input sekali dalam sehari atau tidak boleh lebih dari sekali untuk / tanggal masuk dan keluarnya

Fungsi
Pertama – tama kita buat koneksi database dan tentu saja beberapa fungsi untuk mewadahi 3 query pada desain database diatas

1. database.php

 <?php 

class Database
{
	private $host="localhost";
	private $user="root";
	private $pass="";
	private $db="codexam";
	protected $koneksi;
	public function __construct()
	{
		try
		{
			$this->koneksi = new PDO("mysql:host=$this->host; dbname=$this->db",$this->user, $this->pass);
			$this->koneksi->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

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

2.Absenclass.php


  <?php 
class Absensiswa extends Database
{
	
	public function data_Absen($userid)
	{
		try
		{
			$sql = "SELECT * FROM absen_masuk WHERE userid=$userid";
			$stmt = $this->koneksi->prepare($sql);
			$stmt->execute();
			return $stmt;
		}
		catch(PDOException $e)
		{
			echo $e->getMessage();
		}
	}
	public function cek_Absenmasuk($userid)
	{
		try
		{
			$sql = "SELECT * FROM absen_masuk WHERE tgl_masuk=CURRENT_DATE() AND userid=$userid";
			$stmt = $this->koneksi->query($sql);
			if($stmt->execute())
			{
				if($stmt->rowCount()==1)
				{
					return true;
				}
				else
				{
					return false;
				}
			}
		}
		catch(PDOException $e)
		{
			echo $e->getMessage();
		}
	}
	public function cek_Absenkeluar($userid)
	{
		try
		{
			$sql = "SELECT * FROM absen_masuk WHERE tgl_keluar=CURRENT_DATE() AND userid=$userid";
			$stmt = $this->koneksi->prepare($sql);
			$stmt->execute();
			if($stmt->rowCount()==1)
			{
				return true;
			}
			else
			{
				return false;
			}
		}
		catch(PDOException $e)
		{
			echo $e->getMessage();
		}
	}
	public function get_idabsen($userid)
	{
		//mendapatkan id absen berdasarkan id user yang aktif
		try
		{
			$sql = "SELECT id_absen FROM absen_masuk WHERE tgl_masuk=CURRENT_DATE() AND userid=$userid";
			$stmt = $this->koneksi->prepare($sql);
			$stmt->execute();
			$stmt->bindColumn(1,$this->id_absen);
			$stmt->fetch(PDO::FETCH_BOUND);
			return $this->id_absen?$this->id_absen:''; //akan menghasilkan string kosong jika tidak ada
		}
		catch(PDOException $e)
		{
			echo $e->getMessage();
		}
	}
	public function insert_Absenmasuk($userid, $tgl_masuk, $jam_masuk)
	{
		try
		{
			$sql = "INSERT INTO absen_masuk(userid, tgl_masuk, jam_masuk) VALUES(:userid,:tgl_masuk, :jam_masuk)";
			$stmt = $this->koneksi->prepare($sql);
			$stmt->bindParam(":userid",$userid);
			$stmt->bindParam(":tgl_masuk",$tgl_masuk);
			$stmt->bindParam(":jam_masuk",$jam_masuk);

			$stmt->execute();
			return true;
		}
		catch(PDOException $e)
		{
			echo $e->getMessage();
		}	
	}
	public function update_Absenkeluar($tgl_keluar, $jam_keluar, $id_absen)
	{
		try
		{
			$sql = "UPDATE absen_masuk SET tgl_keluar=:tgl_keluar, jam_keluar=:jam_keluar WHERE id_absen=:id_absen";
			$stmt = $this->koneksi->prepare($sql);
			$stmt->bindParam(":tgl_keluar",$tgl_keluar);
			$stmt->bindParam(":jam_keluar",$jam_keluar);
			$stmt->bindParam(":id_absen",$id_absen);
			$stmt->execute();
			return true;
		}
		catch(PDOException $e)
		{
			echo $e->getMessage();
		}
	}
	public function __destruct()
	{
		return true;
	}
}
  

3. index.php

  <?php

require_once('database.php');
require_once('Absenclass.php');
$obj = new Absensiswa;

$d = $obj->data_Absen(1); //kita set usernya misal punya id satu

?>
<!DOCTYPE html>
<html>
<head>
	<meta charset="utf-8">
	<title>Data Absensi - Tutorial PHP Supaya user hanya bisa input sekali dalam sehari - root93</title>
</head>
<body>
	<div style="margin-top: 20px;">
		<p> Anggap saja disini user sedang aktif dengan membawa sesion yang berisi idnya <br>
		. Jadi kita query berdasarkan iduser pada session</p>
		<table border="1" width="500">

				<tr>
					<th colspan="4">Tutorial PHP - root93</th>

				</tr>
				<tr>

					<th colspan="2"><a href="absen_masuk.php">Absen masuk</a></th>
					<th colspan="2"><a href="absen_keluar.php">Absen keluar</a></th>
				<tr>
					<th>UserId</th>
					<th>Tgl Masuk</th>
					<th>Jam masuk</th>
					<th>Jam Keluar</th>
				</tr>
				<?php
					if($d->rowCount()>0)
					{
					while($row = $d->fetch(PDO::FETCH_ASSOC)){
				?>
				<tr>
					<th><?=$row['userid'];?></th>
					<th><?=$row['tgl_masuk'];?></th>
					<th><?=$row['jam_masuk'];?></th>
					<th><?=$row['jam_keluar'];?></th>
				</tr>
				<?php }}?>

			
		</table>
	</div>
</body>
</html>
  

4. absen_masuk.php

  <?php

require_once('database.php');
require_once('Absenclass.php');
$obj = new Absensiswa;

?>
<!DOCTYPE html>
<html>
<head>
	<meta charset="utf-8">
	<title>Absensi masuk siswa</title>
</head>
<body>
<?php

	# Sebelum kita menampilkan formulir, kita cek dulu apakah dia sudah absen sebelumnya
	if($obj->cek_Absenmasuk(1))
	{
	//jika sudah absen sebelumnya arahkan ke index.php

				echo 
				'
				<script> 
					window.alert("Anda sudah absen hari ini");
					window.location.href="index.php";
					

				</script>
				';
	}
	else
	{
	//jika belum, tampilkan formulirnya
		if($_SERVER['REQUEST_METHOD']=='POST')
		{
			//format tanggal akan dibuat seperti format di mysql
			$tgl_masuk = date('Y-m-d'); 
			$jam_masuk = date('H:i:s');
			if($obj->insert_Absenmasuk(1,$tgl_masuk, $jam_masuk))
			{
				echo 
				'
				<script> 
					window.alert("Anda berhasil absen hari ini");
					window.location.href="index.php";
					

				</script>
				';
				
			}
			else
			{
				echo 
				"
				<script> 
					alert('Anda gagal absen hari ini');
				</script>
				";
				
			}
		}
?>

<form action="<?php $_SERVER['PHP_SELF'];?>" method="post">
	<table style="border: 1px solid #ccc;" width="500px">
		<tr>
			<td colspan="2">Formulir Absen masuk</td>
		</tr>
		<tr>
			<td>Siap untuk absen ?</td>
			<td><input type="submit" name="absen" value="Klik Absen"></td>
		</tr>
		

	</table>
	
</form>


<?php }?>

	</body>
</html>
  

4. absen_keluar.php

  <?php

require_once('database.php');
require_once('Absenclass.php');
$obj = new Absensiswa;

?>
<!DOCTYPE html>
<html>
<head>
	<meta charset="utf-8">
	<title>Absensi masuk siswa</title>
</head>
<body>
<?php
	//pertama kita coba dapatkan dulu id absen berdasarkan data useridnya untuk proses update
	//jika variabel bernilai kosong maka kita kembalikan ke index
	if(empty($obj->get_idabsen(1)))
	{
		echo 
					'
					<script> 
						window.alert("Anda harus melakukan absen masuk terlebih dahulu");
						window.location.href="index.php";
						

					</script>
					';
	}
	else
	{				
		//Selanjutnya kita cek dulu apakah dia sudah melakukan absen keluar sebelumnya
		if($obj->cek_Absenkeluar(1))
		{
		//jika sudah absen sebelumnya arahkan ke index.php

					echo 
					'
					<script> 
						window.alert("Anda sudah absen keluar hari ini");
						window.location.href="index.php";
						

					</script>
					';
		}
		else
		{
		//tapi jika belum, kita lakukan query ke id user untuk mendapatkan id absen berdasarkan tgl masuk
		//jika dia belum melaukan absen masuk maka dia akan dikembalikan ke halaman utama
			if($_SERVER['REQUEST_METHOD']=='POST')
			{
				//format tanggal akan dibuat seperti format di mysql
			
		
				$tgl_keluar = date('Y-m-d');
				$jam_keluar = date('H:i:s');

				if($obj->update_Absenkeluar($tgl_keluar,$jam_keluar,$obj->id_absen))
				{
					echo 
					'
					<script> 
						window.alert("Anda berhasil absen kelaur hari ini");
						window.location.href="index.php";
						

					</script>
					';
					
				}
				else
				{
					echo 
					"
					<script> 
						alert('Anda gagal absen hari ini');
					</script>
					";
					
				}
			}
	
?>

<form action="<?php $_SERVER['PHP_SELF'];?>" method="post">
	<table style="border: 1px solid #ccc;" width="500px">
		<tr>
			<td colspan="2">Formulir Absen keluar</td>
		</tr>
		<tr>
			<td>Siap untuk absen ?</td>
			<td><input type="submit" name="absen" value="Klik Absen keluar"></td>
		</tr>
		

	</table>
	
</form>


<?php }}?>

	</body>
</html>
  





Hasil
Dari kode – kode diatas maka akan menghasilkan beberapa kondisi yang akan terpenuhi 

Tutorial PHP Supaya User Hanya Bisa Input Sekali Dalam Sehari

  • User hanya bisa melakukan absen sekali dalam sehari
  • User yang belum melakukan absen masuk tidak bisa melakukan absen keluar dan atau dia hanya bisa melakukan absen keluar sekali
  • User yang lupa melakukan absen keluar bisa terlihat bahwa jam keluarnya akan terlihat kosong




0 Response to "Tutorial PHP Supaya User Hanya Bisa Input Sekali Dalam Sehari"

Post a Comment

Komentar yang Anda kirim akan terlebih dahulu di moderasi oleh Admin