-->
Mengirim Data Ke Database Memakai Satu File Php
4/ 5 stars - "Mengirim Data Ke Database Memakai Satu File Php" Dalam form input yang bertugas menampung data yang diinputkan oleh user biasanya untuk mengirimkan data yang diinputkan tersebut saya ...

Mengirim Data Ke Database Memakai Satu File Php



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 memakai pertolongan file lain untuk memproses, memvalidasi dan menyimpan datanya ke database server. Tapi bersama-sama kita dapat saja mensubmit filenya pada file/halaman yang sama, maksudnya pada form action kita tidak perlu mengarahkannya ke file lain, jadi pada form action nanti memakai fungsi PHP_SELF

Makara nanti tekniknya ketika ada agresi yang dilakukan oleh user pada form dengan method POST, maka secara otomatis PHP akan merespon, memvalidasi dan menyimpan datanya ke database. Validasi dapat dilakukan ibarat biasa, dalam rujukan kali ini Saya akan memakai percabangan if elseif else untuk melaksanakan validasi pada data yang akan disimpan ke database. Soal validasi memakai 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 memakai 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 ibarat berikut

    Mengirim Data ke Database Menggunakan Satu File PHP Mengirim Data ke Database Menggunakan Satu File PHP
  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 menentukan Database:".mysqli_connect_error()); } ?>  
  3. Terakhir buat form input misal dengan nama kirimdata.php ibarat 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 dihentikan kurang dari 3 karakter"; }elseif(strlen($_POST["nama_mahasiswa"])>5){         $nameErr="Data dihentikan 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 dihentikan kurang 1 karakter"; }elseif(strlen($_POST["umur_mahasiswa"])>2){   $umurErr="Data umur dihentikan 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 sanksi dari user melalui form. Hal ini dibentuk agar 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, jikalau 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 klarifikasi lainnya pada percabangan diatas, dapat Anda baca pada artikel artikel saya wacana validasi form input memakai PHP.


RALAT#
Kode percabangan yang saya jelaskan diatas bersama-sama mempunyai kesalahan untuk kondisi terkahir pada percabangan. Sehingga balasannya ketika data terakhir bernilai benar dan data pertama salah ia tetap melaksanakan ekseskusi ke database. Padahal ketika data kedua bernilai salah dan data pertama benar ia tidak mengeksekusi ke database. Seharusnya kalau ada salah satu data pada percabangan yang salah dihentikan ada sanksi ke database.

Mengirim Data ke Database Menggunakan Satu File PHP 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 alasannya itu pada selesai baris kita kembali lakukan pengecekan terhadap semua variabel, apakah ada data yang bernilai kosong atau tidak, jikalau ada jangan buat sanksi 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 dihentikan kurang dari 3 karakter"; }elseif(strlen($_POST["nama_mahasiswa"])>5){         $nameErr="$background  Data dihentikan 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 dihentikan kurang 1 karakter"; }elseif(strlen($_POST["umur_mahasiswa"])>2){   $umurErr="$background Data umur dihentikan 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 etika data yang salah otomatis variabel benar akan bernilai kosong alias null //maka cek kembali kalau ada data yang bernilai null jangan lakukan sanksi database echo "Masih ada data yang kosong";  }elseif(empty($umur)){ echo "umur masih kosong"; }else{   //terakhir lakukan sanksi $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