Rumah > Artikel > pembangunan bahagian belakang > Bagaimana untuk melaksanakan fungsi anti-goncang dan anti-penyerahan semula dalam PHP
Cara melaksanakan fungsi penyerahan anti goncang dan anti pendua dalam PHP
Dalam pembangunan web, penyerahan anti goncang dan anti pendua adalah dua masalah biasa. Anti-goncang digunakan untuk mengendalikan peristiwa yang sering dicetuskan untuk mengelakkan permintaan yang berlebihan adalah untuk menghalang pengguna daripada menghantar borang yang sama beberapa kali. Artikel ini akan memperkenalkan cara untuk melaksanakan kedua-dua fungsi ini dalam PHP dan menyediakan contoh kod khusus.
1. Pelaksanaan fungsi anti goncang
Fungsi anti goncang terutamanya melakukan operasi tertentu sekali sahaja dalam tempoh masa tertentu. Dalam PHP, anda boleh menggunakan sesi untuk mencapai fungsi anti-goncang. Langkah-langkah khusus adalah seperti berikut:
<?php session_start(); function debounce($callback, $delay = 1000) { if(isset($_SESSION['debounce_timer'])) { return; } $callback(); $_SESSION['debounce_timer'] = time() + $delay; register_shutdown_function('debounce_reset_timer'); } function debounce_reset_timer() { unset($_SESSION['debounce_timer']); }
<?php function handleInput() { // 处理AJAX请求 } debounce('handleInput', 1000);
Antaranya, fungsi handleInput()
为处理AJAX请求的函数,1000为防抖延迟时间,当用户输入框输入时,会在1秒后调用handleInput()
, jika pengguna memasukkan secara berterusan, hanya akan melaksanakan operasi input terakhir.
2. Pelaksanaan fungsi penyerahan anti-ulang
Menghalang pengguna daripada menghantar semula borang adalah keperluan yang sangat biasa. Fungsi anti-penyerahan semula boleh dicapai dengan menggunakan token. Langkah-langkah khusus adalah seperti berikut:
<?php session_start(); function generateToken() { $_SESSION['submit_token'] = md5(uniqid(rand(), true)); return $_SESSION['submit_token']; } $token = generateToken();
<input type="hidden" name="submit_token" value="<?php echo $token; ?>">
<?php session_start(); function validateToken($token) { if(isset($_SESSION['submit_token']) && $token === $_SESSION['submit_token']) { unset($_SESSION['submit_token']); return true; } return false; } if($_POST && validateToken($_POST['submit_token'])) { // 处理表单提交逻辑 }
Melalui pelaksanaan di atas, apabila pengguna menyerahkan borang, PHP akan mengesahkan sama ada token yang diserahkan sepadan dengan token dalam sesi Jika ia sepadan, logik pemprosesan borang akan dilaksanakan jika ia tidak sepadan bahawa ia adalah penyerahan berulang, dan anda boleh melakukan Pemprosesan yang sepadan, seperti menggesa pengguna.
Ringkasan
Melalui kerjasama sesi dan token, fungsi penyerahan anti-goncang dan anti-ulang boleh dilaksanakan dalam PHP. Langkah pelaksanaan khusus telah diperkenalkan secara terperinci dalam artikel ini, dan contoh kod yang sepadan disediakan untuk rujukan saya harap ia akan membantu anda.
Atas ialah kandungan terperinci Bagaimana untuk melaksanakan fungsi anti-goncang dan anti-penyerahan semula dalam PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!