Maison >développement back-end >tutoriel php >Conseils ThinkPHP pour éviter les soumissions répétées de formulaires
Pendant le développement, si un Ajoutez ou modifiez le formulaire. Après avoir terminé l' opération de base de données en arrière-plan, nous définissons s'il faut passer à d'autres pages ou revenir à cette page. À ce moment, cliquez sur le bouton de retour du navigateur et puis la soumission ou l'actualisation de la page entraînera la soumission répétée du formulaire form, c'est-à-dire que cet enregistrement sera ajouté ou modifié deux fois. La raison pour laquelle
provoque la soumission du formulaire. à plusieurs reprises est : la première soumission. Le formulaire sera mis en cache dans la mémoire et disparaîtra jusqu'à la prochaine fois que la page sera soumise ou que la page sera fermée ou redirigée vers une autre page. Lorsque l'auto-appel reviendra, le. les données en mémoire sont toujours là, puis le jugement dans la page est soumis. Le code peut toujours détecter la valeur soumise, mais cela produira l'effet d'une soumission répétée
Méthode 1 : La plus simple : après avoir soumis la page, allez sur une autre page à la place de celle-ci page. Par exemple, par exemple, l'adresse de votre page est
http://yourdomain.com/User/Index/loginEnsuite, l'adresse du formulaire
action de la page peut être une autre adresse de traitement, telle que
<form action="{:U('User/Index/check_login')}" method="post">, qui signale une erreur et renvoie, ou l'utilisateur clique sur le bouton retour
Méthode 2 : Après avoir soumis le formulaire, le bouton de soumission devient gris/masque le bouton de soumission
Cette méthode est généralement effectuée en combinaison avec la méthode 1. Elle utiliseJS pour surveiller dynamiquement les actions de clic de l'utilisateur et définir dynamiquement l'attribut du bouton pour qu'il soit désactivé, ce qui signifie qu'il est gris et désactivé. Le code est le suivant : HTML :
JS :<form action="{:U('User/Index/check_login')}" method="post">Après la combinaison de la méthode 1+la méthode 2, en gros plus de 90 % des questions de soumission en double peuvent toutes être résolues, mais Liu quand même veut parler de la troisième méthode, qui consiste à résoudre ce problème une fois pour toutes côté serveur
$().ready(function(){ $("#login_btn").on('click',function(){ $(this).attr('disabled',true); }); });Méthode 3
: Utiliser la méthode de masquage des valeurs aléatoires de TOKEN pour répéter Soumettre jugementTout d'abord, ajoutez la méthode suivante dans le fichier function.php du projet
Remplissez le code HTML suivant dans le formulaire de la page de formulaire//创建TOKEN function createToken() { $code = chr(mt_rand(0xB0, 0xF7)) . chr(mt_rand(0xA1, 0xFE)) . chr(mt_rand(0xB0, 0xF7)) . chr(mt_rand(0xA1, 0xFE)) . chr(mt_rand(0xB0, 0xF7)) . chr(mt_rand(0xA1, 0xFE)); session('TOKEN', authcode($code)); } //判断TOKEN function checkToken($token) { if ($token == session('TOKEN')) { session('TOKEN', NULL); return TRUE; } else { return FALSE; } } /* 加密TOKEN */ function authcode($str) { $key = "YOURKEY"; $str = substr(md5($str), 8, 10); return md5($key . $str); }
HTML :
Appelez la méthode creatToken() pour générer un jeton avant l'affichage de la page et utilisez checkToken() dans le<input type="hidden" name="TOKEN" value="{:session('TOKEN')}" />contrôleur
Requête POST correspondante pour déterminer s'il faut soumettre à plusieurs reprises
Fondamentalement, ces trois méthodes peuvent être utilisées ensemble pour résoudre le problème de la soumission répétée de formulaires dans le développement ThinkPHP. Bien sûr, certains étudiants ont dit que vous pouvez utiliser le mécanisme d'anneau à jetons de ThinkPHP, qui est en fait. plus simple. TP va Par défaut, un champ caché est généré dans le formulaire. À ce moment-là, on peut juger si le champ caché existe et s'il correspond à la valeur de la session. Le principe est le même que la méthode 3.if(IS_POST) { $post_token = I('post.TOKEN'); if(!checkToken($post_token)){ $this->error('请不要重复提交页面',U('User/Index/login')); } }
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!