Foros del Web » Programando para Internet » PHP »

Envio de formulario

Estas en el tema de Envio de formulario en el foro de PHP en Foros del Web. Hola a todo! Estoy intentando aprender algo de web y decidí hacer una pequeña web de prueba para ver que soy capaz de hacer. El ...
  #1 (permalink)  
Antiguo 03/01/2013, 16:43
Avatar de mbm150  
Fecha de Ingreso: enero-2013
Ubicación: Muskiz
Mensajes: 79
Antigüedad: 11 años, 2 meses
Puntos: 21
Pregunta Envio de formulario

Hola a todo!

Estoy intentando aprender algo de web y decidí hacer una pequeña web de prueba para ver que soy capaz de hacer.

El caso es que quiero actualizar un apartado usando UPDATE pero no consigo que funcione y me estoy volviendo loco.

La idea es que saca datos de la bd y los muestra, entonces yo le doy a aprobar o rechazar y en la base de datos, en el apartado MARCA (que se supone esta en blanco) me pone eso (Aprobar o Rechazar).

Esto es lo que he hecho (solo pongo el cacho que no funciona):

if($aprobado==""){
echo "
<article class='principal'>
<a href='$enlace.php'><span class='categoria'>$categoria</span></a>
<span class='nombre'>Enviado: $fecha, $hora por $sexo <a>$nombre</a></span>
<p>$chiste</p>
</article>
<form action='' method='post' class='aprobar2'>
<select name='marca'>
<option>Aprobar</option> <option>Rechazar</option>
</select>
<input type='submit' value='Ok'>
</form>
<article class='separador'></article>";
}

Me muestra todo bien, pero cuando le doy a Ok no pasa nada (el action esta vacio...)

Supongo que hay formas mejores de hacerlo pero es lo único que se me ha ocurrido. No se que poner en action (supongo que un enlace a otro php) y hacer que funcione.

Gracias por su ayuda.
  #2 (permalink)  
Antiguo 03/01/2013, 17:24
Avatar de David
Moderador
 
Fecha de Ingreso: abril-2005
Ubicación: In this planet
Mensajes: 15.720
Antigüedad: 18 años, 11 meses
Puntos: 839
Respuesta: Envio de formulario

Esto te ayudará a entender cómo procesar el formulario:
http://php.net/variables.external

Saludos.
__________________
Por favor, antes de preguntar, revisa la Guía para realizar preguntas.
  #3 (permalink)  
Antiguo 03/01/2013, 18:12
Avatar de mbm150  
Fecha de Ingreso: enero-2013
Ubicación: Muskiz
Mensajes: 79
Antigüedad: 11 años, 2 meses
Puntos: 21
Pregunta Respuesta: Envio de formulario

He leido y no se si he entendido bien...

Esto he hecho (esta casi igual):
Código PHP:
Ver original
  1. $consulta = mysql_query("SELECT * FROM cronicas ORDER BY ID DESC", $con);
  2.                                                                                    
  3. while($row=mysql_fetch_array($consulta)){
  4.     $id=$row['ID'];
  5.     $categoria=$row['CATEGORIA'];
  6.     $buscaFecha=$row['FECHA'];
  7.     $nombre=$row['NOMBRE'];
  8.     $aprobado=$row['MARCA'];
  9.  
  10. if($aprobado==""){
  11.     echo "
  12.         <article class='principal'>
  13.             <a href='$enlace.php'><span class='categoria'>$categoria</span></a>
  14.             <span class='nombre'>Enviado: $fecha, $hora <a>$nombre</a></span>
  15.         </article>
  16.         <form action='prueba.php' method='post' class='aprobar2'>
  17.             <select name='marca'>
  18.                     <option>Aprobar</option>
  19.                 <option>Rechazar</option>
  20.             </select>
  21.             <input type='submit' value='Ok'>
  22.         </form>
  23.         <article class='separador'></article>";
  24. }

Y el prueba.php:

Código PHP:
Ver original
  1. <?php
  2.         $host="localhost";
  3.     $user="";
  4.     $pw="";
  5.     $db="";
  6.                            
  7.     $con=mysql_connect($host, $user, $pw)
  8.     or die("Problemas al conectar con el servidor");
  9.            
  10.     mysql_select_db($db, $con)
  11.     or die("Problemas al conectar con la base de datos");
  12.  
  13.     mysql_query("UPDATE cronicas SET MARCA=$_POST['marca'] WHERE ID='$id'", $con);
  14.    
  15.     echo "
  16.         <script>
  17.         function dirigir(){location.href='http://www.lapizarrina.com/atxis/es/moderar.php'}
  18.         setTimeout('dirigir()', 0);
  19.         </script>";
  20. ?>

La duda es, al estar en otro archivo lo de $_POST funciona bien? y la id que también esta en el otro funcionaria o tengo que volver a sacarla en ese nuevo?
  #4 (permalink)  
Antiguo 03/01/2013, 18:23
Avatar de andresdzphp
Colaborador
 
Fecha de Ingreso: julio-2011
Ubicación: $this->Colombia;
Mensajes: 2.749
Antigüedad: 12 años, 8 meses
Puntos: 793
Respuesta: Envio de formulario

el id también necesitas enviarlo (puede ser en un input de tipo "hidden")

Aquí tienes un error de sintaxis:

Código PHP:
Ver original
  1. mysql_query("UPDATE cronicas SET MARCA=$_POST['marca'] WHERE ID='$id'", $con);

$_POST['marca'] debes encerrarlo entre llaves { } o concatenar.

Anuncio: Extensión MySQL obsoleta

Saludos.
__________________
Si sabemos como leer e interpretar el manual será mucho más fácil aprender PHP. En lugar de confiar en ejemplos o copiar y pegar - PHP
  #5 (permalink)  
Antiguo 03/01/2013, 18:42
Avatar de emprear
Colaborador
 
Fecha de Ingreso: junio-2007
Ubicación: me mudé
Mensajes: 8.388
Antigüedad: 16 años, 9 meses
Puntos: 1567
Respuesta: Envio de formulario

Si estás empezando te recomendaría comiences por el método sencillo, esto es
Creas un php que lea la tabla y si $aprobado = "" genere un form para ese registro, por lo que decís eso lo has logrado.

Ahora ese nuevo form debe apuntar a un nuevo php (actualizar.php, por ejemplo) que haga el update,
¿que debería contener ese nuevo form?

<form action="actualizar.php" method="post">

el select, al que debería agregarles los value correspondientes

<select name='marca'>
<option value="aprobar">Aprobar</option>
<option value="rechazar">Rechazar</option>
</select>

un campo hidden con un valor único que identifique al registro, puede ser el $id
<input type="hidden" name="id" value="$id" />

Luego, en actualizar.php tras el update, confirmás la actualización verificando que
mysql_affected_rows();
ó
mysqli_affected_rows()
según que extensión de php uses
de ser > 0 haces la redirección con
header('Location: .....);

Si podés con esto, ya si después podés intentar cosas más avanzadas
integrar todo en un solo php
utilizar un iframe oculto como destino del form
utilizar ajax para procesar el form
etc

SAludos
__________________
La voz de las antenas va, sustituyendo a Dios.
Cuando finalice la mutación, nueva edad media habrá
S.R.
  #6 (permalink)  
Antiguo 03/01/2013, 18:42
Avatar de mbm150  
Fecha de Ingreso: enero-2013
Ubicación: Muskiz
Mensajes: 79
Antigüedad: 11 años, 2 meses
Puntos: 21
Sonrisa Respuesta: Envio de formulario

Muchas gracias a los 3, ya he solucionado el problema (O por lo menos parece que funciona). Al final he hecho:

Código PHP:
Ver original
  1. $id=$_POST['oculto'];
  2. $marca=$_POST['marca'];
  3.  
  4. mysql_query("UPDATE cronicas SET MARCA='$marca' WHERE ID='$id'", $con);

No tenia muy claro lo de POST y GET pero en esa página lo explica.
Creo que hoy he aprendido algo. Poco a poco intentare subir el nivel xD. Gracias.

Última edición por mbm150; 03/01/2013 a las 18:48
  #7 (permalink)  
Antiguo 03/01/2013, 18:50
Avatar de David
Moderador
 
Fecha de Ingreso: abril-2005
Ubicación: In this planet
Mensajes: 15.720
Antigüedad: 18 años, 11 meses
Puntos: 839
Respuesta: Envio de formulario

Es importante también que leas esto:
http://php.net/manual/es/security.da...-injection.php
__________________
Por favor, antes de preguntar, revisa la Guía para realizar preguntas.

Etiquetas: mysql
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 06:07.