Mengirim Data ke Database Menggunakan Satu File PHP

Mengirim Data ke Database Menggunakan Satu File PHP

Dalam form input yang bertugas menampung data yang diinputkan oleh user biasanya untuk mengirimkan data yang diinputkan tersebut saya sering menggunakan bantuan file lain untuk memproses, memvalidasi dan menyimpan datanya ke database server. Tapi sebenarnya kita bisa saja mensubmit filenya pada file/halaman yang sama, maksudnya pada form action kita tidak perlu mengarahkannya ke file lain, jadi pada form action nanti menggunakan fungsi PHP_SELF

Jadi nanti tekniknya ketika ada aksi yang dilakukan oleh user pada form dengan method POST, maka secara otomatis PHP akan merespon, memvalidasi dan menyimpan datanya ke database. Validasi bisa dilakukan seperti biasa, dalam contoh kali ini Saya akan menggunakan percabangan if elseif else untuk melakukan validasi pada data yang akan disimpan ke database. Soal validasi menggunakan php ini sudah pernah saya bahas pada artikel – artikel sebelumnya, sehingga untuk kali ini kita akan mencoba mengimplementasikannya.

Baca juga :
 
Dalam kesempatan ini saya akan mencontohkan bagaimana mensubmit/mengirim data pada halaman yang sama atau tanpa berpindah halaman menggunakan satu file PHP. Dalam tutorial kali ini saya akan mencontohkan bagaimana mengirim data nama dan umur mahasiswa ke database MySQL

  1. Buat Database Dengan struktur seperti berikut

    database mahasiswa
  2. Selanjutnya buat file dengan nama koneksi.php
    
    <?php
    $host="localhost";
    $user="root";
    $pass="";
    $db="mahasiswa";
    $koneksi=mysqli_connect($host,$user,$pass);
    if(!$koneksi){
    echo"Gagal Melakukan Koneksi:".mysqli_connect_error();
    exit();
    }
    $pilihdb= mysqli_select_db($koneksi,$db);
    if(!$pilihdb) {
     echo("Gagal memilih Database:".mysqli_connect_error());
    }
    ?>
    
    
  3. Terakhir buat form input misal dengan nama kirimdata.php seperti berikut ini

    <!DOCTYPE HTML>  
    <html>
    <head>
    <style>
    .error {color: #FF0000;}
    </style>
    </head>
    <body>  
    
    <?php
    include('koneksi.php');
    //mengeset nilai variabel data yang kosong
    $nameErr = $umurErr = ""; 
    $name  = $umur =  "";
    
    if ($_SERVER["REQUEST_METHOD"] == "POST") {
    if (empty($_POST["nama_mahasiswa"])) {
        $nameErr = "Name is required";
    }elseif(!preg_match("/^[a-zA-Z ]*$/",$_POST["nama_mahasiswa"])) {
          $nameErr = "Hanya krakter alphabet yang diperbolehkan"; 
    }elseif(strlen($_POST["nama_mahasiswa"])<3){
            $nameErr="Data tidak boleh kurang dari 3 karakter";
    }elseif(strlen($_POST["nama_mahasiswa"])>5){
            $nameErr="Data tidak boleh lebih dari 5 karakter";
    }else{
    //kondisi benar kumpulkan nilai variabel
          $name=test_input($_POST["nama_mahasiswa"]);
          $name = mysqli_real_escape_string($koneksi,$name);
      
     
          
      }
    if(empty($_POST["umur_mahasiswa"])){
      $umurErr="Umur is Required";
    }elseif(!preg_match("/^[0-9]*$/",$_POST["umur_mahasiswa"])){
    $umurErr="Hanya data angka yang diperbolehkan";
    }elseif(strlen($_POST["umur_mahasiswa"])<1){
      $umurErr="Data umur tidak boleh kurang 1 karakter";
    }elseif(strlen($_POST["umur_mahasiswa"])>2){
      $umurErr="Data umur tidak boleh lebih dari 2 karakter";
    }else{
      //kondisi benar kumpulkan nilai variabel
      $umur=test_input($_POST["umur_mahasiswa"]);
      $umur= mysqli_real_escape_string($koneksi,$umur);
      
    //Query Terakhir
    $perintah=sprintf("INSERT INTO mhs VALUES('null','%s','%d')",$name,$umur);
    $jalankan=mysqli_query($koneksi, $perintah);
    if(!$jalankan){
      echo "Gagal menyimpan data=".mysqli_error();
    }else{
      echo "Berhasil Menyimpan data";
    }
    
    
    }
    
    }
    
    function test_input($data) {
      $data = trim($data);
      $data = stripslashes($data);
      $data = htmlspecialchars($data);
      return $data;
    }
    ?>
    
    
    <h2>PHP Form Validation Example</h2>
    <p><span class="error">* required field.</span></p>
    <form method="post" action="<?php echo htmlspecialchars($_SERVER["PHP_SELF"]);?>">  
      
      Name: <input type="text" name="nama_mahasiswa" id="nama_mahasiswa" value="<?php echo $name; ?>" />
      <span class="error">* <?php echo $nameErr;?></span>
      <br><br>
    
       Umur: <input type="text" name="umur_mahasiswa" id="umur_mahasiswa" value="<?php echo $umur; ?>" />
      <span class="error">* <?php echo $umurErr;?></span>
      <br><br>
    
       <input type="submit" name="submit" id="submit" value="Submit"> 
       <input type="reset" name="batal" id="batal" value="Batal"> 
    </form>
    
    
    </body>
    </html>

Penjelasan – Penjelasan :

$nameErr = $umurErr = "";
$name = $umur = "";

Kondisi ketika variabel kosong atau belum ada eksekusi dari user melalui form. Hal ini dibuat supaya variabel yang dipanggil atau ditambahkan di form tidak mengalami error atau undefined variabel saat/sebelum terjadi request post

if ($_SERVER["REQUEST_METHOD"] == "POST")
Maksudnya ketika ada request POST yang dilakukan oleh user untuk mengirim data, maka PHP akan merespon dan menjalankan perintah

if (empty($_POST["nama_mahasiswa"]))

Mengecek apakah data sudah diisi atau belum, jika belum PHP akan menyimpan sebuah variabel error, dan memanggil di form

$name=test_input($_POST["nama_mahasiswa"]);
$name = mysqli_real_escape_string($koneksi,$name);

Ketika kondisi benar terpenuhi (data benar), data akan disimpan kedalam variabel

Untuk penjelasan lainnya pada percabangan diatas, bisa Anda baca pada artikel – artikel saya tentang validasi form input menggunakan PHP.


RALAT#
Kode percabangan yang saya jelaskan diatas sebenarnya memiliki kesalahan untuk kondisi terkahir pada percabangan. Sehingga akibatnya ketika data terakhir bernilai benar dan data pertama salah dia tetap melakukan ekseskusi ke database. Padahal ketika data kedua bernilai salah dan data pertama benar dia tidak mengeksekusi ke database. Seharusnya kalau ada salah satu data pada percabangan yang salah tidak boleh ada eksekusi ke database.

Mengirim Data ke Database Menggunakan Satu File PHP


Logikanya :
Ketika data pertama mengalami kesalahan, maka secara otomatis variabelnya nilai (benar) akan dalam kondisi kosong, oleh karena itu pada akhir baris kita kembali lakukan pengecekan terhadap semua variabel, apakah ada data yang bernilai kosong atau tidak, jika ada jangan buat eksekusi ke database. Contoh :

<!DOCTYPE HTML>  
<html>
<head>
  
<style>

.error {color: #FF0000;}
</style>
</head>
<body>  
<?php $background="<error-daftar style='background:pink; padding:10px; border-radius:3px'>"; ?>

<?php

include('koneksi.php');
//mengeset nilai variabel data yang kosong
$nameErr = $umurErr = $errErr = ""; 
$name  = $umur = $err =  "";

if ($_SERVER["REQUEST_METHOD"] == "POST") {
if (empty($_POST["nama_mahasiswa"])) {
    $nameErr = "$background Name is required";
}elseif(!preg_match("/^[a-zA-Z ]*$/",$_POST["nama_mahasiswa"])) {
      $nameErr = "$background Hanya krakter alphabet yang diperbolehkan"; 
}elseif(strlen($_POST["nama_mahasiswa"])<3){
        $nameErr="$background Data tidak boleh kurang dari 3 karakter";
}elseif(strlen($_POST["nama_mahasiswa"])>5){
        $nameErr="$background  Data tidak boleh lebih dari 5 karakter";
}else{
//kondisi benar kumpulkan nilai variabel
      $name=test_input($_POST["nama_mahasiswa"]);
      $name = mysqli_real_escape_string($koneksi,$name);
  
}
if(empty($_POST["umur_mahasiswa"])){
  $umurErr="$background  Umur is Required";
}elseif(!preg_match("/^[0-9]*$/",$_POST["umur_mahasiswa"])){
$umurErr="$background Hanya data angka yang diperbolehkan";
}elseif(strlen($_POST["umur_mahasiswa"])<1){
  $umurErr="$background Data umur tidak boleh kurang 1 karakter";
}elseif(strlen($_POST["umur_mahasiswa"])>2){
  $umurErr="$background Data umur tidak boleh lebih dari 2 karakter";
}else{
  //kondisi benar kumpulkan nilai variabel
  $umur=test_input($_POST["umur_mahasiswa"]);
  $umur= mysqli_real_escape_string($koneksi,$umur);
}
//Eksekusi Terakhir
if(empty($name)) {
//Ketika adat data yang salah otomatis variabel benar akan bernilai kosong alias null
//maka cek kembali kalau ada data yang bernilai null jangan lakukan eksekusi database
echo "Masih ada data yang kosong"; 
}elseif(empty($umur)){
echo "umur masih kosong";
}else{
  //terakhir lakukan eksekusi
$perintah=sprintf("INSERT INTO mhs VALUES('null','%s','%d')",$name,$umur);
$jalankan=mysqli_query($koneksi, $perintah);
if(!$jalankan){
$errErr="Gagal menyimpan data=".mysqli_error();
}else{
$err="Berhasil Menyimpan data";
}
}
//
}

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

?>


<h2>PHP Form Validation Example</h2>
<p><span class="error">* required field.</span></p>
<form method="post" action="<?php echo htmlspecialchars($_SERVER["PHP_SELF"]);?>">  
  
  Name: <input type="text" name="nama_mahasiswa" id="nama_mahasiswa" value="<?php echo $name; ?>" />
  <span class="error"><?php echo $nameErr;?></span>
  <br><br>

   Umur: <input type="text" name="umur_mahasiswa" id="umur_mahasiswa" value="<?php echo $umur; ?>" />
  <span class="error"><?php echo $umurErr;?></span>
  <br><br>

   <input type="submit" name="submit" id="submit" value="Submit"> 
   <input type="reset" name="batal" id="batal" value="Batal"> 
</form>
<br/>
<span class="error"><?php echo $err;?></span>
<span class="error"><?php echo $errErr;?></span>
</body>
</html>s


0 Response to "Mengirim Data ke Database Menggunakan Satu File PHP"

Post a Comment

Komentar yang Anda kirim akan terlebih dahulu di moderasi oleh Admin