Script PHP untuk Mencegah Submit Form Berulang Kali
October 6th, 2008 | by rosihanari |
Cetak Artikel Ini
Pernahkah Anda mendapati seseorang yang telah mensubmit form yang ada di situs Anda beberapa kali dalam waktu yang hampir bersamaan? Biasanya hal ini dilakukan oleh user yang mengira proses submit form belum sukses, sehingga ia berulang kali mengklik REFRESH atau mengklik tombol SUBMIT padahal sebenarnya proses submit sendiri sudah berhasil. Apabila data dari form tersebut disimpan di database maka Anda akan mendapati beberapa data yang sama (duplicate data).
Lebih buruk lagi, seandainya yang mengirim data melalui form adalah sebuah spam yang bisa jadi akan menghabiskan space quota hostingan Anda di server karena puluhan bahka ratusan data akan disubmit dalam waktu yang hampir bersamaan melalui form.
Nah… berikut ini ada tips untuk menanggulangi submit form yang berulang kali tersebut.
Misalkan Anda memiliki form berikut ini
form.php
1 2 3 4 | <form method="post" action="submit.php"> <p>Masukkan nama Anda: <input name="nama" type="text" /></p> <p><input type="submit" /></p> </form> |
Form di atas digunakan untuk memasukkan nama user lalu mensubmitnya. Ini hanyalah contoh sederhana saja. Anda dapat membuat beberapa field tambahan bila diperlukan.
Teknik untuk mencegah submit berulang kali disini menggunakan bantuan session. Bagaimana idenya? OK… Pertama-tama untuk inisialisasi, session dibuat bernilai TRUE. Submit dikatakan berhasil jika nilai session yang tadinya bernilai TRUE, kemudian berubah menjadi FALSE. Sedangkan apabila submit belum berhasil maka status session masih TRUE dan memungkinkan user melakukan re-submit. Apabila submit sebelumnya berhasil (status session menjadi FALSE), maka ia tidak bisa mensubmit lagi.
Nah, oleh karena itu kita harus modifikasi script untuk formnya untuk menerapkan ide di atas.
form.php
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | <?php // memulai session session_start(); // jika session belum dibuat, maka inisialisasi awal diberi nilai TRUE if (!isset($_SESSION['submit'])) { $_SESSION['submit'] = true; } ?> <form method="post" action="submit.php"> <p>Masukkan nama Anda: <input name="nama" type="text" /></p> <p><input type="submit" /></p> </form> |
Nah selanjutnya kita buat script untuk memproses submitnya.
submit.php
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 | <?php session_start(); // cek apabila submit tidak valid if (!$_SESSION['submit']) { echo "ERROR: form sudah disubmit sebelumnya!"; } else { // mengubah session menjadi false setelah submit sukses $_SESSION['submit'] = false; // Bagian ini dapat dimodifikasi sendiri sesuai keperluan // misalnya ditambah perintah untuk // entri data ke tabel database // dalam contoh ini data yang diisi via form // hanya sekedar ditampilkan saja setelah disubmit echo "Nama anda".$_POST['nama']; } ?> |
OK… begitu kira-kira tips sederhana untuk mengatasi submit data yang berulang-ulang via form. Selamat mencoba dan mudah-mudahan bermanfaat bagi Anda. Nantikan tips-tips berikutnya dari saya, so… stay tune terus di blog ini.
Beberapa artikel terkait
- Beberapa Trik Mencegah Submit Polling Berulang Kali
- Penggunaan Cookie untuk Mencegah Submit Ganda pada Polling
- Beberapa Tombol Submit dalam Satu Form
- Alternatif Cara Membuat Form Dinamis Untuk Submit Data Secara Simultan
- Script PHP untuk Mengedit Data Via Form
- Script PHP untuk Edit Data dengan Komponen RadioButton pada Form
- Teknik Submit Data Melalui Multi Form
- Tentang Letak Script Pengolah Form
- Alternatif Script Untuk Memproses Input Data Form Dinamis
- Script PHP Untuk Update Password Administrator
Share this article on:
Kata kunci: PHP -
Mau kaos (T-shirt) Wordpress keren? (
Rosihan Ari adalah seorang programmer, penulis buku, trainer, peneliti dan berusaha menjadi seorang blogger sejati dengan memberikan yang terbaik buat negeri ini. Berfokus pada computer programming serta computer aided learning for mathematics, ia ingin berbagi ilmu yang dimilikinya. 


Keren
Thk mas, artikelnya.. sedang di coba..
gimana kalo browsernya dimatiin trus dihidupin lg, berarti qt jg hrs menambahkan cookie, tapi gimana lagi kalo cookienya dihapus.. koq google bisa ya.. apa pake IPnya, gimana kalo pake IP palsu, intinya cara nyari IP yg sebenernya tuh gimana ya, bingung saya..
inginnya spt ini: jika IP proxy ada maka tulis larangan untuk mensubmit, gimana tuh crnya
kalo’ disubmit ke file itu sendiri bs tidak y?