Skip to content Skip to sidebar Skip to footer

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 menolongan file lain untuk memproses, memvalidasi dan menyimpan datanya ke database server. Tapi sebetulnya 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

Kaprikornus nanti metodenya 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 menyerupai biasa, dalam teladan 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 peluang 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 melaluiataubersamaini struktur menyerupai diberikut

    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 menyerupai diberikut 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 dilarang kurang dari 3 karakter"; }elseif(strlen($_POST["nama_mahasiswa"])>5){         $nameErr="Data dilarang 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 dilarang kurang 1 karakter"; }elseif(strlen($_POST["umur_mahasiswa"])>2){   $umurErr="Data umur dilarang 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 semoga variabel yang dipanggil atau dimenambahkan 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, bila 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 sebetulnya mempunyai kesalahan untuk kondisi terkahir pada percabangan. Sehingga hasilnya ketika data terakhir bernilai benar dan data pertama salah beliau tetap melaksanakan ekseskusi ke database. Padahal ketika data kedua bernilai salah dan data pertama benar beliau tidak mengeksekusi ke database. Seharusnya kalau ada salah satu data pada percabangan yang salah dilarang 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 ialah itu pada simpulan baris kita kembali lakukan pengecekan terhadap tiruana variabel, apakah ada data yang bernilai kosong atau tidak, bila ada tidakboleh buat sanksi ke database. misal :

<!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 dilarang kurang dari 3 karakter"; }elseif(strlen($_POST["nama_mahasiswa"])>5){         $nameErr="$background  Data dilarang 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 dilarang kurang 1 karakter"; }elseif(strlen($_POST["umur_mahasiswa"])>2){   $umurErr="$background Data umur dilarang 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 watak data yang salah otomatis variabel benar akan bernilai kosong alias null //maka cek kembali kalau ada data yang bernilai null tidakboleh 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


Post a Comment for "Mengirim Data Ke Database Memakai Satu File Php"