Maison >développement back-end >tutoriel php >Conseils ThinkPHP pour éviter les soumissions répétées de formulaires

Conseils ThinkPHP pour éviter les soumissions répétées de formulaires

PHPz
PHPzoriginal
2017-04-04 15:03:251405parcourir

Pourquoi y a-t-il des formulaires en double ?

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

Comment le résoudre

En résumant les solutions en ligne et vos propres tests, vous pouvez utiliser les méthodes suivantes :

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/login
Ensuite, l'adresse du formulaire

action de la page peut être une autre adresse de traitement, telle que

<form action="{:U(&#39;User/Index/check_login&#39;)}" method="post">
, qui signale une erreur et renvoie, ou l'utilisateur clique sur le bouton retour

et revient toujours à l'adresse précédente, mais ce n'est pas sûr dans ce cas. Il est également plus sûr d'utiliser la méthode 2.

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 utilise

JS 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(&#39;User/Index/check_login&#39;)}" 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(&#39;TOKEN&#39;)}" />
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'));
  }
}

Conseils ThinkPHP pour éviter les soumissions répétées de formulaires

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn