Foros del Web » Programando para Internet » PHP »

Como evitar que se envíen campos vacíos en un formulario

Estas en el tema de Como evitar que se envíen campos vacíos en un formulario en el foro de PHP en Foros del Web. Hola amigos, en esta semana he estado haciendo una web de libros en la cual ahora solo me falta incrementar un sistema de comentarios he ...
  #1 (permalink)  
Antiguo 11/03/2013, 13:28
 
Fecha de Ingreso: enero-2013
Mensajes: 18
Antigüedad: 11 años, 3 meses
Puntos: 5
Pregunta Como evitar que se envíen campos vacíos en un formulario

Hola amigos, en esta semana he estado haciendo una web de libros en la cual ahora solo me falta incrementar un sistema de comentarios he llegado a hacer el formulario y la conexión a la base de datos, y los comentarios se envían correctamente pero mi problema es que quiero evitar que por curiosidad le den clic al botón de enviar y se envíen los campos vacíos. Este es mi código:

Código PHP:
<form action="libro.php?id=<?php echo $_GET['id']?>" method="post" />  
Nombre:  
<br/>  
<input type="text" name="user"/>  
<br/>  
Comentarios:  
<br/>  
<textarea name="comment"></textarea>  
<br/>  
<br/>  
<input type="text" name="id_nt" value="<?php echo $_GET['id']?>"/>  
<input type="submit" value="Enviar" />  
</form>

<?PHP
    
    
include("connection.php");
    
    
mysql_query("INSERT INTO comments (id_nt,user,comment)  
    VALUES('$_REQUEST[id_nt]','$_REQUEST[user]','$_REQUEST[comment]')"
,$connection)or die(mysql_error());
    
?>
Mi objetivo es que si los campos están vacíos al presionar el botón den enviar, mande un mensaje informando que los campos no pueden estar vacíos. Quisiera informar que todo esto quisiera hacerlo en la mis página (libro.php) ¿Alguien podría echarme una mano? Gracias:)
  #2 (permalink)  
Antiguo 11/03/2013, 13:32
Avatar de maycolalvarez
Colaborador
 
Fecha de Ingreso: julio-2008
Ubicación: Caracas
Mensajes: 12.120
Antigüedad: 15 años, 9 meses
Puntos: 1532
Respuesta: Como evitar que se envíen campos vacíos en un formulario

debes de validar (preferiblemente con javascript) que estén vacíos o no.

ten en cuenta que para que tu formulario sea seguro, la validación SIEMPRE la debes hacer desde PHP, es decir, del lado del servidor.

la validación del lado del cliente (javascript) no aporta seguridad, sí, es cómoda y le ahorra peticiones innecesarias al server, pero NO es segura, de allí lo importante que es tener al del servidor, y de preferencia ambas
__________________
¡Por favor!: usa el highlight para mostrar código
El que busca, encuentra...
  #3 (permalink)  
Antiguo 11/03/2013, 13:43
 
Fecha de Ingreso: enero-2013
Mensajes: 18
Antigüedad: 11 años, 3 meses
Puntos: 5
Respuesta: Como evitar que se envíen campos vacíos en un formulario

Cita:
Iniciado por maycolalvarez Ver Mensaje
debes de validar (preferiblemente con javascript) que estén vacíos o no.

ten en cuenta que para que tu formulario sea seguro, la validación SIEMPRE la debes hacer desde PHP, es decir, del lado del servidor.

la validación del lado del cliente (javascript) no aporta seguridad, sí, es cómoda y le ahorra peticiones innecesarias al server, pero NO es segura, de allí lo importante que es tener al del servidor, y de preferencia ambas
Hola, gracias por tu pronta respuesta, había intentado hace poco hacerlo con javascript y lograba que al usuario se le enviara un mensaje de que algún campo estaba vacío, pero de igual manera el 'mensajes' (Con campos vacíos) se envía. Dejare mi código para ver si me podrías indicar mi error. Gracias.

Código HTML:
<head>
<script language="JavaScript" type="text/JavaScript">
function validate_send(){
if(document.comments.user.value == "") {
alert("Por favor indique Su Nombre");
document.comments.user.focus();
return false;
}

if(document.comments.comment.value == "") {
alert("Por favor ingrese un comentario");
document.comments.comment.focus();
return false;
}

alert("Muchas gracias por tu comentario");
document.comments.submit(); 
return true;
}
</script>
</head>

<body>
<form action="<?php echo $_GET['id']?>" method="post" name="comments">  
Nombre:  
<br/>  
<input type="text" name="user"/>  
<br/>  
Comentarios:  
<br/>  
<textarea name="comment"></textarea>  
<br/>  
<br/>  
<input type="text" name="id_nt" value="<?php echo $_GET['id']?>"/>  
<input type="submit" value="Enviar" onclick="validate_send()"/>  
</form>

<?php 
	
	include("../connection.php");
	
	mysql_query("INSERT INTO comments (id_nt,user,comment)  
	VALUES('$_REQUEST[id_nt]','$_REQUEST[user]','$_REQUEST[comment]')",$connection)or die(mysql_error());
	
?> 
</body> 
  #4 (permalink)  
Antiguo 11/03/2013, 14:52
 
Fecha de Ingreso: abril-2010
Ubicación: Cancun
Mensajes: 88
Antigüedad: 14 años
Puntos: 2
Respuesta: Como evitar que se envíen campos vacíos en un formulario

tu Script lo ejecuta total anida tus if algo asi

Código:
<script language="JavaScript" type="text/JavaScript">
function validate_send(){
if(document.comments.user.value == "") {
alert("Por favor indique Su Nombre");
document.comments.user.focus();
}
else{
if(document.comments.comment.value == "") {
alert("Por favor ingrese un comentario");
document.comments.comment.focus();
}
else{//Paso por las dos validaciones ahora mandamos formulario
alert("Muchas gracias por tu comentario");
document.comments.submit(); 
}
}
}

</script>
  #5 (permalink)  
Antiguo 11/03/2013, 15:13
Avatar de Nemutagk
Colaborador
 
Fecha de Ingreso: marzo-2004
Ubicación: México
Mensajes: 2.633
Antigüedad: 20 años
Puntos: 406
Respuesta: Como evitar que se envíen campos vacíos en un formulario

Eso es porque la validación no esta funcionando como tal, es mejor que ancles esa función en el evento submit del formulario...

Código HTML:
Ver original
  1. <script language="JavaScript" type="text/JavaScript">
  2. function validate_send(){
  3. if(document.comments.user.value == "") {
  4. alert("Por favor indique Su Nombre");
  5. document.comments.user.focus();
  6. return false;
  7. }
  8.  
  9. if(document.comments.comment.value == "") {
  10. alert("Por favor ingrese un comentario");
  11. document.comments.comment.focus();
  12. return false;
  13. }
  14.  
  15. alert("Muchas gracias por tu comentario");
  16. return true;
  17. }
  18. </head>
  19.  
  20. <form action="<?php echo $_GET['id']?>" method="post" name="comments" onsubmit="return validate_send()">  
  21. Nombre:  
  22. <br/>  
  23. <input type="text" name="user"/>  
  24. <br/>  
  25. Comentarios:  
  26. <br/>  
  27. <textarea name="comment"></textarea>  
  28. <br/>  
  29. <br/>  
  30. <input type="text" name="id_nt" value="<?php echo $_GET['id']?>"/>  
  31. <input type="submit" value="Enviar"/>  
  32. </form>
  33. </body>

Pero tal cual te ah dicho @maycolalvarez, debes hacer también la validación del lado del servidor, ya que es muy facil saltar dicha validación en javascript...
__________________
Listo?, tendría que tener 60 puntos menos de IQ para considerarme listo!!!
-- Sheldon Cooper
http://twitter.com/nemutagk
PD: No contestaré temas vía mensaje personal =)

Etiquetas: campos, comentarios, formulario, sql, vacios
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 14:58.