Mau kaos (T-shirt) Wordpress keren? (Selengkapnya)
Dapatkan Script SMS Gateway PHP + MySQL

Seperti: software pengirim SMS massal, SMS survei, SMS polling, SMS quick count, SMS dakwah, Web2SMS dan masih banyak lagi... semuanya berbasis PHP & MySQL
[Info Lengkap...]



Script PHP untuk Mencegah Submit Form Berulang Kali


October 6th, 2008 | by rosihanari | Cetak Artikel Ini 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


Share this article on:

Kata kunci: PHP -


Ada 4 komentar dalam artikel ini.

  1. kereayem says:

    Thk mas, artikelnya.. sedang di coba..

  2. d'sixTein says:

    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 :D

  3. kliwon says:

    kalo’ disubmit ke file itu sendiri bs tidak y?



Tolong beri komentar donk!

Komentar Anda akan berguna untuk kemajuan blog ini.


Mohon maaf, komentar yang menggunakan email palsu atau komentar bernada negatif atau cemooh secara otomatis akan terhapus karena dianggap spam dan tidak akan tampil dalam daftar komentar.

Dimohon jangan pula memasukkan code program dalam bentuk apapun ke dalam komentar karena akan dianggap spam.

*
Untuk membuktikan bahwa komentar Anda bukan spam, tulis kata yang muncul dalam gambar di bawah ini. Bila Anda tidak bisa membaca kata dalam gambar, klik pada gambar tersebut untuk mendengarkan suara dari kata tersebut
Click to hear an audio file of the anti-spam word