Главная->Уроки по php->Отмена повторной отправки формы

Отмена повторной отправки формы

15 Фев в 00:56

Отмена повторной отправки формы Мне часто задают вопросы относительно отмены повторной отправки формы. Например, Вы сделали форму добавления комментария, добавили обработчик на эту же страницу. Затем при добавлении комментария он успешно добавляется, но стоит пользователю нажать F5, как форма будет отправлена ещё раз. А F5 пользователь может легко нажать, если страница будет долго грузиться. В итоге, вместо 1-го комментария будет целых 2, а то и больше. В этой статье я покажу, как этого можно избежать. Для начала разберём более подробно проблему на примере этого кода: <?php if (!empty($_POST["sqr"])) { echo "Квадрат числа ".$_POST["x"]." равен ".pow($_POST["x"], 2); } ?> <form name="form" action="" method="post"> <div> <input type="text" name="x" /> <br /> <input type="submit" value="Возвести в квадрат" name="sqr" /> </div> </form> Нажав на кнопку "Возвести в квадрат", Вы увидите результат работы скрипта. Но стоит после этого пользователю нажать F5, как скрипт снова будет выполняться. В данном случае, это не так критично, как с добавлением комментарием, однако, зачем нужна лишняя нагрузка на сервер? Теперь поговорим о способах решения данной проблемы. Первый способ - выделить скрипт обработки в отдельный файл. Тогда в атрибуте action у тега form надо добавить путь к этому скрипту. А сам скрипт должен сохранять куда-нибудь результат своих действий, либо переменные пришедшие на скрипт, а после делать редирект обратно. В общем, смотрите код скрипта: <?php session_start(); $_SESSION["x"] = $_POST["x"]; header("Location: ".$_SERVER["HTTP_REFERER"]); exit; ?> А код страницы с формой теперь будет выглядеть так: <?php session_start(); if (isset($_SESSION["x"])) echo "Квадрат числа ".$_SESSION["x"]." равен ".pow($_SESSION["x"], 2); } ?> <form name="form" action="request.php" method="post"> <div> <input type="text" name="x" /> <br /> <input type="submit" value="Возвести в квадрат" name="sqr" /> </div> </form> Недостаток этого подхода очевиден - приходится создавать ещё один файл для такого простого скрипта. Поэтому рассказываю и про второй способ, как можно избежать повторной отправки формы: <?php session_start(); if (!empty($_POST["sqr"])) { $_SESSION["x"] = $_POST["x"]; header("Location: ".$_SERVER["REQUEST_URI"]); exit; } if (isset($_SESSION["x"])) echo "Квадрат числа ".$_SESSION["x"]." равен ".pow($_SESSION["x"], 2); ?> <form name="form" action="" method="post"> <div> <input type="text" name="x" /> <br /> <input type="submit" value="Возвести в квадрат" name="sqr" /> </div> </form> Здесь обработка снова происходит в этом же файле, но ключевое отличие - это наличие редиректа на эту же страницу в конце. В результате, страница перегрузится после отправки формы и браузер при нажатии F5 не будет предлагать пользователю отправить форму ещё раз. Подведу итог того, как отменить повторную отправку формы: Либо делать обработку в отдельном файле, а затем оттуда делать редирект назад. Либо делать обработку в том же файле, что и форма, но при этом после обработки делать редирект на ту же страницу. Вот так это делается в простых скриптах. Да и, в сложных, в конечном счёте делается то же самое.