Heim  >  Artikel  >  PHP-Framework  >  Thinkphp-Tipps zur Vermeidung wiederholter Formularübermittlungen

Thinkphp-Tipps zur Vermeidung wiederholter Formularübermittlungen

尚
nach vorne
2020-04-11 09:02:192771Durchsuche

Wenn während der Entwicklung ein Formular hinzugefügt oder geändert wird, legen wir nach Abschluss des Datenbankvorgangs im Hintergrund fest, ob zu anderen Seiten gesprungen oder zu dieser Seite zurückgekehrt werden soll. Klicken Sie zu diesem Zeitpunkt vor dem Absenden oder Aktualisieren auf die Schaltfläche „Zurück“ des Browsers Die Seite führt dazu, dass das Formular wiederholt gesendet wird, d. h. dieser Datensatz wird zweimal hinzugefügt oder geändert.

Thinkphp-Tipps zur Vermeidung wiederholter Formularübermittlungen

Der Grund dafür, dass das Formular wiederholt gesendet wird, besteht darin, dass das zum ersten Mal gesendete Formular im Speicher zwischengespeichert wird, bis die Seite das nächste Mal oder die Seite gesendet wird geschlossen oder auf andere Seiten umgeleitet wird. Wenn der Selbstaufruf zurückkehrt, sind die Daten im Speicher noch vorhanden. Zu diesem Zeitpunkt kann der übermittelte Code auf der Seite den übermittelten Wert noch erkennen, was den Effekt einer wiederholten Übermittlung verursacht.

Sie können die folgenden Methoden verwenden, um das Problem zu lösen:

Methode 1: Die einfachste: Gehen Sie nach dem Absenden der Seite zu einer anderen Seite anstelle dieser Seite, zum Beispiel zu Ihrer Seite Wenn die Adresse

http://yourdomain.com/User/Index/login

ist, kann die Formularaktionsadresse der Seite eine andere Verarbeitungsadresse sein, z. B.

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

, die einen Fehler meldet und zurückgibt, oder der Benutzer klickt auf die Schaltfläche „Zurück“ und kehrt trotzdem zurück an die vorherige Adresse, aber auch diese Situation ist nicht sicher. Es ist auch notwendig, Methode 2 abzugleichen, um gemeinsam sicherer zu sein

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

Diese Methode wird normalerweise mit Methode 1 kombiniert und erfolgt über JS. Überwachen Sie dynamisch die Klickaktion des Benutzers und setzen Sie das Schaltflächenattribut dynamisch auf deaktiviert, was bedeutet, dass es grau und nicht verfügbar ist. Der Code lautet wie folgt:

HTML:

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

JS:

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

Nach der Kombination von Methode 1 + Methode 2 können grundsätzlich mehr als 90 % der Probleme mit der doppelten Einreichung gelöst werden , aber die meisten von ihnen möchten hier über die dritte Methode sprechen, die darin besteht, dieses Problem ein für alle Mal auf der Serverseite zu lösen

Methode 3: Verwenden Sie die Methode zum Ausblenden zufälliger TOKEN-Werte Bewerten Sie wiederholte Einreichungen

Fügen Sie zunächst im Projekt die folgende Methode zu „functions.php“ hinzu

//创建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(&#39;TOKEN&#39;, authcode($code));
}
//判断TOKEN
function checkToken($token) {
    if ($token == session(&#39;TOKEN&#39;)) {
       session(&#39;TOKEN&#39;, NULL);
       return TRUE;
    } else {
      return FALSE;
    }
}
/* 加密TOKEN */
function authcode($str) {
    $key = "YOURKEY";
    $str = substr(md5($str), 8, 10);
    return md5($key . $str);
}

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

HTML:

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

Rufen Sie die creatToken()-Methode auf, bevor die Seite angezeigt wird, um ein Token zu generieren. Verwenden Sie checkToken() in der entsprechenden Controller-POST-Anfrage, um zu bestimmen, ob wiederholt gesendet werden soll

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

Im Grunde sind es diese drei Methoden kann zusammen verwendet werden, um das Problem der wiederholten Übermittlung von Formularen in der ThinkPHP-Entwicklung zu lösen. Ein Klassenkamerad sagte, dass Sie den Token-Ring-Mechanismus von ThinkPHP verwenden können, der tatsächlich einfacher ist und standardmäßig ein verstecktes Feld im Formular generiert Dann können Sie beurteilen, 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.

Empfohlenes Tutorial: Thinkphp-Tutorial

Das obige ist der detaillierte Inhalt vonThinkphp-Tipps zur Vermeidung wiederholter Formularübermittlungen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:csdn.net. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen