Heim  >  Artikel  >  Backend-Entwicklung  >  ThinkPHP-Tipps, wie Sie wiederholte Formularübermittlungen verhindern können

ThinkPHP-Tipps, wie Sie wiederholte Formularübermittlungen verhindern können

PHPz
PHPzOriginal
2017-04-04 15:03:251337Durchsuche

Warum gibt es doppelte Formulare?

Wenn während der Entwicklung ein Fügen Sie hinzu oder ändern Sie das Formular. Nachdem wir den Datenbankvorgang im Hintergrund abgeschlossen haben, legen wir fest, ob zu anderen Seiten gesprungen oder zu dieser Seite zurückgekehrt werden soll. Klicken Sie zu diesem Zeitpunkt auf die Zurück-Schaltfläche des Browsers und Dann führt das Absenden oder Aktualisieren der Seite dazu, dass das Formular für wiederholt gesendet wird. Das heißt, dieser Datensatz wird zweimal hinzugefügt oder geändert. Der Grund, warum

dazu führt, dass das Formular gesendet wird wiederholt: Das Formular wird im Speicher zwischengespeichert und verschwindet, bis die Seite das nächste Mal geschlossen oder auf eine andere Seite umgeleitet wird Die Daten im Speicher sind noch vorhanden, und der Code kann den übermittelten Wert weiterhin erkennen, aber er erzeugt den Effekt einer wiederholten Übermittlung.

Wenn Sie die Online-Lösungen und Ihre eigenen Tests zusammenfassen, können Sie die folgenden Methoden verwenden:

Methode 1

: Die einfachste: Gehen Sie nach dem Absenden der Seite stattdessen zu einer anderen Seite Beispielsweise lautet Ihre Seitenadresse

. Dann kann die Formularadresse
http://yourdomain.com/User/Index/login
Aktion

der Seite eine andere Verarbeitungsadresse sein, beispielsweise

, wodurch ein Fehler gemeldet wird und der Benutzer auf die Schaltfläche „Zurück“
<form action="{:U(&#39;User/Index/check_login&#39;)}" method="post">
klickt und dennoch zur vorherigen Adresse zurückkehrt. In diesem Fall ist es jedoch nicht sicherer, Methode 2 zu verwenden

Methode 2

: Nach dem Absenden des Formulars wird die Schaltfläche „Senden“ grau/versteckt die Schaltfläche „Senden“

Diese Methode wird im Allgemeinen in Kombination mit Methode 1 durchgeführt. Sie verwendet JS

, um die Klickaktionen des Benutzers dynamisch zu überwachen und das

-Attribut der Schaltfläche dynamisch zu deaktivieren, was bedeutet, dass es grau und deaktiviert ist. Der Code lautet wie folgt: HTML:

JS:

<form action="{:U(&#39;User/Index/check_login&#39;)}" method="post">
   
   
   

Nach der Kombination von Methode 1 + Methode 2 können grundsätzlich mehr als 90 % der doppelten Einreichungsfragen gelöst werden, aber Liu immer noch Ich möchte über die dritte Methode sprechen, die darin besteht, dieses Problem ein für alle Mal auf der Serverseite zu lösen

$().ready(function(){
     $("#login_btn").on('click',function(){
            $(this).attr('disabled',true);
      });
});

Methode 3

: Verwenden Sie die Methode zum Ausblenden zufälliger TOKEN-Werte, um das Senden zu wiederholen Beurteilung

Fügen Sie zunächst die folgende Methode in die Datei „functions.php“ des Projekts ein

Füllen Sie den folgenden HTML-Code in das Formularseitenformular ein

//创建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:

Rufen Sie die creatToken()-Methode auf, um ein Token zu generieren, bevor die Seite angezeigt wird, und verwenden Sie checkToken() in der entsprechenden

Controller
<input type="hidden" name="TOKEN" value="{:session(&#39;TOKEN&#39;)}" />

POST-Anfrage, um zu bestimmen, ob eine erneute Übermittlung erfolgen soll Grundsätzlich können diese drei Methoden zusammen verwendet werden, um das Problem der wiederholten Formularübermittlung in der ThinkPHP-Entwicklung zu lösen. Natürlich sagten einige Studenten, dass Sie den Token-Ring-Mechanismus von ThinkPHP verwenden können, der tatsächlich einfacher ist. TP wird standardmäßig ein ausgeblendetes Feld im Formular generieren. Zu diesem Zeitpunkt kann beurteilt werden, ob das ausgeblendete Feld vorhanden ist und ob es mit dem Wert in der Sitzung übereinstimmt. Das Prinzip ist das gleiche wie bei Methode 3.

if(IS_POST)
{
$post_token = I('post.TOKEN');
  if(!checkToken($post_token)){
      $this->error('请不要重复提交页面',U('User/Index/login'));
  }
}

ThinkPHP-Tipps, wie Sie wiederholte Formularübermittlungen verhindern können

Das obige ist der detaillierte Inhalt vonThinkPHP-Tipps, wie Sie wiederholte Formularübermittlungen verhindern können. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn