Wie verhindert PHP, dass das Formular wiederholt gesendet wird?)
Der Benutzer sendet das Formular an das Backend und markiert es im Cookie Die Zeit wird ungültig. Diese Methode schlägt jedoch fehl, wenn der Benutzer Cookies deaktiviert.
<?php if (isset($_COOKIE['formFlag'])) { exit('error'); } // 处理数据 // 30秒内重复提交无效 setcookie('formFlag', time(), time() + 30);
SitzungBeim Anzeigen der Formularseite wird eine Zufallszahl generiert und in der Sitzung und im ausgeblendeten Feld des Formulars gespeichert. Bei der ersten Übermittlung löscht der Vergleich den Wert in der Sitzung erfolgreich.
Durch die Verwendung der Sitzungsfunktion von PHP kann auch das wiederholte Absenden von Formularen vermieden werden. Die Sitzungsvariable wird auf der Serverseite gespeichert. Wenn Sie das nächste Mal auf diese Variable zugreifen, können Sie den von Ihnen übermittelten Wert mit einer Sitzungsvariablen aufzeichnen Wenn es nicht übereinstimmt, wird davon ausgegangen, dass es sich um den Benutzer handelt, der wiederholt sendet.
<?php if (!isset($_SESSION['formFlag']) || $_POST['formFlag'] != $_SESSION['formFlag']) { exit('error'); } // 处理数据 unset($_SESSION['formFlag']);
Das obige ist der detaillierte Inhalt vonSo verhindern Sie, dass Formulare in PHP wiederholt gesendet werden. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!