Cómo detener el reenvío de formularios en la actualización de la página
9 respuestas
- votos
-
- 2013-04-20
En lugar de…
} else { echo "<p>Your file has been uploaded.</p>"; }
} else { $new_url = add_query_arg( 'success', 1, get_permalink() ); wp_redirect( $new_url, 303 ); exit; }
El código deestado 303 activa una solicitud GET :
Este Estemétodoexisteprincipalmenteparapermitir que la salida de un script activadopor POST redirija al agente de usuario a un recurso seleccionado. Elnuevo URInoes una referencia sustituta del recurso solicitado originalmente. La respuesta 303 NO DEBE almacenarseen caché,pero la respuesta a la segunda solicitud (redirigida)podría almacenarseen caché.
En En su controlador deformularios compruebeprimero si
$_GET['success']
está configurado y su valores1
,luegoimprima unmensaje de éxito. El visitantepuede volver a cargarestapágina una y otra vez,yno seenviaránada.Instead of …
} else { echo "<p>Your file has been uploaded.</p>"; }
… redirect to another address on success:
} else { $new_url = add_query_arg( 'success', 1, get_permalink() ); wp_redirect( $new_url, 303 ); exit; }
Status code 303 triggers a GET request:
This method exists primarily to allow the output of a POST-activated script to redirect the user agent to a selected resource. The new URI is not a substitute reference for the originally requested resource. The 303 response MUST NOT be cached, but the response to the second (redirected) request might be cacheable.
In your form handler check first if
$_GET['success']
is set and its value is1
, then print a success message. The visitor can reload this page again and again – and nothing will be sent.-
Desafortunadamente,esonofuncionó,ynotengoidea depor quéporqueesephp sepega (solopara confirmar quetodo lo que se suponía que debía hacerera reemplazareleco.Unfortunately that didn't work, and I have no idea why because that php does stick up (just to confirm all I was supposed to do was replace the echo?
- 0
- 2013-04-20
- ameeromar
-
Debeenviarelencabezado antes de que seenvíe cualquier salida alnavegador.You have to send the header before any output has been sent to the browser.
- 1
- 2013-04-20
- fuxia
-
Entonces,¿ponerelbit de códigophpen elencabezado?so put the php code bit in the header?
- 0
- 2013-04-26
- ameeromar
-
@ameeromar Sí.Todoelprocesamiento de datos debe realizarse antes de comenzar a crear resultados.@ameeromar Yes. All data processing should be done before you start creating output.
- 2
- 2013-04-26
- fuxia
-
- 2013-09-11
Tuveelmismoproblema yfue "complicado"porel hecho de que redirigítodas las URL a un solo archivo .php.Resultó quetodo lo quetuve que hacerpara resolverlofueinsertarel siguientefragmento de código antes de que seescriba cualquier HTMLen lapágina.
<?php if (isset($_POST['mypostvar']) && isset($_SERVER['REQUEST_URI'])) { [process the post data in 'mypostvar'] header ('Location: ' . $_SERVER['REQUEST_URI']); exit(); } ?>
Esto lo redireccionará a lamismapágina después de que los datosposteriores seprocesen como lo desea. Después de la redirección,los datosposteriores originales desaparecen yno activaránel reenvío. Lafunción 'header ()' solofuncionará si lainserta antes de que seescriba algoen lapágina. exit ()esnecesario.
Tienes queprocesar los datos de lapublicación antes de colocarelencabezado ().
I had the same problem and it was "complicated" by the fact that I redirect all URLs to a single .php file. It turned out all I had to do to solve it was to insert the following piece of code before any html is written to the page.
<?php if (isset($_POST['mypostvar']) && isset($_SERVER['REQUEST_URI'])) { [process the post data in 'mypostvar'] header ('Location: ' . $_SERVER['REQUEST_URI']); exit(); } ?>
This will redirect to the same page after the postdata is processed as you want it. After the redirect the original postdata is vanished and will not trigger the resubmit. The function 'header()' will only work if you insert it before anything is written to the page. exit() is necessary.
You have to process the post data before you place the header().
-
- 2018-05-11
Básicamente,laideagenerales redirigir al usuario a otraspáginas después delenvío delformulario,lo que detendríael reenvío delformulario al actualizar lapágina,pero sinecesitamantener al usuarioen lamismapágina después deenviarelformulario,puede hazlo de variasformas.
Datos deformulariono definidos
Unaforma de detenerel reenvío de lapágina al actualizar lapáginaes desarmar los datos delformulario después deenviarlopara que la variable que almacena los datos delformulario quede vacía yterminarelbloque de códigos deprocesamiento delformulariopara verificar sielformularioestá vacío.
if (!empty ($ _ POST) && $ _SERVER ['REQUEST_METHOD']=='POST') { $ data=//procesando códigos aquí unset $ data; }
Esto hará que $ data se vacíen después delprocesamiento y laprimera cláusula detendráel reenvío delformulario al actualizar lapágina.
<× Javascript ×
Estemétodoesbastantefácil ybloquea la ventanaemergente quepideel reenvío delformulario al actualizar una vez que seenvíaelformulario. Simplemente coloqueesta línea de códigojavascript alpie de su archivo y vea lamagia.
& lt; script > if (window.history.radaState) { window.history.rufaState (nulo,nulo,window.location.href); } & lt;/script >
Basically, the general idea is to redirect the user to some other pages after the form submission which would stop the form resubmission on page refresh but if you need to hold the user in the same page after the form is submitted, you can do it in multiple ways.
Unset Form Data
One way to stop page resubmission on page refresh is to unset the form data after it is submitted so that the variable storing form data becomes empty and wrap up your form processing block of codes to check if the form is empty.
if(!empty($_POST) && $_SERVER['REQUEST_METHOD'] == 'POST'){ $data = // processing codes here unset $data; }
This will make $data empty after processing and the first clause would stop form resubmission on page refresh.
Javascript
This method is quite easy and blocks the pop up asking for form resubmission on refresh once the form is submitted. Just place this line of javascript code at the footer of your file and see the magic.
<script> if ( window.history.replaceState ) { window.history.replaceState( null, null, window.location.href ); } </script>
-
- 2013-09-12
Resolvíesto usando la accióntemplate_redirect (ya seaen un complemento oen su archivofunctions.php detemas).
add_action('template_redirect','myfunction') ; function myfunction() { global $post; $post_id = $post->ID; if ( isset( $_POST['html-upload'] ) && !empty( $_FILES ) ) { require_once(ABSPATH . 'wp-admin/includes/admin.php'); $id = media_handle_upload('async-upload', $post_id); //post id of Client Files page unset($_FILES); if ( is_wp_error($id) ) { $errors['upload_error'] = $id; $id = false; } } $error = ($errors) ? 1 : 0; wp_redirect( "/?p={$post_id}?errors={$error}",301); }
Luego,en supágina,puede verificar si hayerrores
if ($_GET['errors']) { echo "<p>There was an error uploading your file.</p>"; } else { echo "<p>Your file has been uploaded.</p>"; }
(No heprobadoeste código ... debería darte unbuenpunto departida).
I solved this my using the template_redirect action (either in a a plugin or on your themes functions.php file).
add_action('template_redirect','myfunction') ; function myfunction() { global $post; $post_id = $post->ID; if ( isset( $_POST['html-upload'] ) && !empty( $_FILES ) ) { require_once(ABSPATH . 'wp-admin/includes/admin.php'); $id = media_handle_upload('async-upload', $post_id); //post id of Client Files page unset($_FILES); if ( is_wp_error($id) ) { $errors['upload_error'] = $id; $id = false; } } $error = ($errors) ? 1 : 0; wp_redirect( "/?p={$post_id}?errors={$error}",301); }
Then on your page you can check for errors
if ($_GET['errors']) { echo "<p>There was an error uploading your file.</p>"; } else { echo "<p>Your file has been uploaded.</p>"; }
(I've not tested this code.. it should give you a good starting point).
-
Con `global $post`en laprimera línea,lasposibilidades de queestafunciónfuncione aumentarán ...With `global $post` in first line, chances this function works will increase...
- 1
- 2013-09-12
- gmazzap
-
- 2013-09-12
Tambiénpuedeprobar
$_SERVER['REQUEST_METHOD'] === 'POST'
para asegurarse de que lapágina se haya actualizadomediante POST antes deprocesarelformulario.if ( $_SERVER['REQUEST_METHOD'] === 'POST' ) { // Do Stuff }
You can also test for
$_SERVER['REQUEST_METHOD'] === 'POST'
to make sure that the page has been refreshed via POST before processing the form.if ( $_SERVER['REQUEST_METHOD'] === 'POST' ) { // Do Stuff }
-
- 2016-01-09
unaformamásfácileseliminar la acción de suformulario ytener una acción oculta,porejemplo:
<html> <form action="" method="post><input type="text" name="name" /> <input type="submit" value="Submit" /> <input type="hidden" name="action" value="Submit" /> </form> </html>
haga que su controlador verifique la validez y losenvíospara verificar sielformulariofueenviado:
<?php if (isset($_POST['action']) && $_POST['action'] == 'Submit'){ //you should add code to validate user input here //if all ok submit the form header('Location: .'); //redirects to the controller without resubmitting } ?>
estemétodoesmuy útilpara scriptsen los queestá agregando oeliminando registrosen unapágina de administración,ya que recargaría lapágina sin volver aenviarla yel registroeliminado o agregado seeliminaría o agregaría a lapágina :)
an easier way is to remove the action from your form and have a hidden action so for example:
<html> <form action="" method="post><input type="text" name="name" /> <input type="submit" value="Submit" /> <input type="hidden" name="action" value="Submit" /> </form> </html>
have your controller checking for validity and for submissions so to check if the form was submitted:
<?php if (isset($_POST['action']) && $_POST['action'] == 'Submit'){ //you should add code to validate user input here //if all ok submit the form header('Location: .'); //redirects to the controller without resubmitting } ?>
this method is very useful for scripts where you are adding or removing records on an admin page as it would reload the page without resubmitting and the record removed or added would be either removed or added to the page :)
-
- 2017-06-23
Elmejormétodo queencontrées usarjavascript y css.Encabezado delmétodo de redirecciónphp común ('Ubicación: http://www.yourdomain.com/url );funcionaráperoprovocará una advertencia "Advertencia: No sepuedemodificar lainformación delencabezado - losencabezados ya seenviaron"en diferentesmarcos y cms como wordpress,drupal,etc. Así quemi sugerenciaes seguirel siguiente código
echo '<style>body{display:none;}</style>'; echo '<script>window.location.href = "http://www.siteurl.com/mysuccesspage";</script>'; exit;
Laetiqueta deestiloesimportante,de lo contrario,el usuariopuede sentir que lapágina se cargó dos veces.Si usamos unaetiqueta deestilo sinmostrarel cuerpo y luego actualizamos lapágina,entonces laexperiencia del usuario será lamisma que la delencabezadophp ('Ubicación: ....);
Espero queesto ayude :)
The best method I found is using javascript and css. Common php redirection method header('Location: http://www.yourdomain.com/url); will work but It cause warning " Warning: Cannot modify header information - headers already sent" in different frameworks and cms like wordpress, drupal etc. So my suggestion is to follow the below code
echo '<style>body{display:none;}</style>'; echo '<script>window.location.href = "http://www.siteurl.com/mysuccesspage";</script>'; exit;
The style tag is important otherwise the user may feel like page loaded twice. If we use style tag with body display none and then refresh the page , then the user experience will be like same as php header('Location: ....);
I hope this will help :)
-
- 2020-04-30
Solución 1: Siestáinsertando unapublicaciónen eltipo depublicación,simplementegenereel código aleatorio usando lafunciónphp
rand()
yguardeel códigomientrasinserta lapublicación.También configureelmismo códigoen la variable$_POST['uniqueid']
.Luego,verifiqueen insertar siel ID único actualestáen laspublicaciones ono,puede hacer lomismo usando
wp_query()
.Solución 2: Redirigir a otrapágina usandojavascript.Pero,porfavor,el usuarionopuede volver a lapágina y volver aguardar lapublicación al actualizar.Paraesteproblema,laprimera soluciónes lamejor.
Solución 3: Use ajaxparainsertar lapublicación,no habráproblemas comoeste.Pero si quieres visitas a lapágina.Noes unabuenaidea,puede serpara Google Adsense.
Intenté ayudar conmi experiencia.Si alguiennecesita un códigopara solucionarelproblema,simplementepregunte,se lo compartiré.
Solution 1 : If you are inserting post in post type then just generate the random code using
rand()
php function and save the code while inserting post. Also set the same code in$_POST['uniqueid']
variable.Then check on insert if the the current uniqueid is there in posts or not, you can do the same using
wp_query()
.Solution 2 : Redirect to another page using javascript. But kindly not that user can go back to page and on again it will save post on refresh. For this issue the first solution is best.
Solution 3 : Use ajax to insert post there will be no issues like this. But if you want page hits. It's not a good idea, may be for Google Adsense.
I just tried to help by my experience. If anyone need code to fix the problem, simply ask, I will share.
-
- 2014-12-07
laforma sencilla yfácil de hacerestoen php. ejemplo aquí:
no olvide lasetiquetas html (esteformulariono lopermite aquí,así que uso [esto])
$firstname = $post[firstname] $lastname = $post[lastname] [form action="here.php" method="post"] first name[input type='firstname' name='firstname'] last name[input type='text' name='lastname'] [input type=submit value=submit] [/form] if($firstname==""||$lastname=="") { echo"the firstname and lastname are empty"; } else { mysql_query("YOUR DATABASE INSERT HERE"); header("Location:here.php"); }
estaes laforma deevitar que los datosingresadosen labase de datospubliquen losmismos datos dos veces al actualizar lapágina
the simple and easy way to do this in php. example here:
dont forget the html tags(this form wont allow it here so i use [this])
$firstname = $post[firstname] $lastname = $post[lastname] [form action="here.php" method="post"] first name[input type='firstname' name='firstname'] last name[input type='text' name='lastname'] [input type=submit value=submit] [/form] if($firstname==""||$lastname=="") { echo"the firstname and lastname are empty"; } else { mysql_query("YOUR DATABASE INSERT HERE"); header("Location:here.php"); }
this is how to keep the data enter in the database from posting the same data twice on page refresh
Hola,tengo unformulario que agrega archivos adjuntos a unapublicación,sinembargo,cuandoelformulariopublica,obviamentenomuestra lapublicación conelnuevo archivo adjunto que haceeco de "su archivo ha sido cargado". Cuandoel usuario actualiza lapágina (paraintentarmostrar sunuevo archivo adjunto),elformulario sepublica denuevo.
¿Esposible (1) detener lapublicación delformularionuevamente al actualizar,(2) actualizar automáticamente lapáginaparamostrar lapublicación con sunuevo archivo adjunto? (2esmuchomejor)
¡Gracias! :)