Foros del Web » Programando para Internet » PHP »

Recibir varios post con el mismo nombre ayud!!!

Estas en el tema de Recibir varios post con el mismo nombre ayud!!! en el foro de PHP en Foros del Web. Hola, estoy programando una parte de un sitio, que consta de traspaso de articulos entre almacenes, en el que, el usuario de un almacen selecciona ...
  #1 (permalink)  
Antiguo 12/10/2012, 08:33
 
Fecha de Ingreso: diciembre-2009
Mensajes: 3
Antigüedad: 9 años, 10 meses
Puntos: 0
Pregunta Recibir varios post con el mismo nombre ayud!!!

Hola, estoy programando una parte de un sitio, que consta de traspaso de articulos entre almacenes, en el que, el usuario de un almacen selecciona todos los articulos a traspasar y el almacen de destino... la cuestion es esta...
El checkbox para activar el input para seleccionar una cantidad se llama "Seleccionado", Su valor, es el ID del producto... Del input, El nombre es cantidad<ID>, ejemplo: cantidad3, cantidad4, etc...
A la hora de enviar los datos, no logro recibir todos los datos y de hecho me da el error de
Warning: Invalid argument supplied for foreach()

El codigo es el siguiente, alguien puede decirme que hago mal???

Código PHP:
<?php 
if (isset($_POST['seleccionado'])) {
$origen=$_POST['origen'];
$destino=$_POST['destino'];
$seleccionado=$_POST['seleccionado'];
$select=count($seleccionado);
echo 
"<script>alert('$select');</script>"//Lo uso para saber si me hace el conteo pero siempre me da a 1 por mas articulos que seleccione
$i=1;
foreach(
$select as $valor){
if(
$valor!=0){
while(
$i<=$select){
$cantidad=$_POST["cantidad$valor"];
$stockpropio=mysql_query("select stock_propio from rel_articulo_almacen where id_almacen=$origen and id_articulo=$valor");
$stockfinal=$stockpropio-$cantidad;
mysql_query("UPDATE rel_articulo_almacen SET stock_propio=$stockfinal where id_almacen=$origen and id_articulo=$valor");
$stockdestino=mysql_query("select stock_propio from rel_articulo_almacen where id_almacen=$destino and id_articulo=$valor");
$stockfinal=$stockdestino+$cantidad;
mysql_query("update rel_articulo_almacen set stock_propio=$stockfinal where id_almacen=$destino and id_articulo=$valor");
$afect=mysql_affected_rows();
if(
$afect==0){
mysql_query("insert into rel_articulo_almacen(stock_propio, id_almacen,id_articulo,aprestamo) values ('$stockfinal','$destino','$valor','0')");
}
$i++;
}
}
}
}
En ejecución se ve así:

Última edición por aazb; 12/10/2012 a las 08:40
  #2 (permalink)  
Antiguo 12/10/2012, 08:50
Avatar de informacionsys  
Fecha de Ingreso: mayo-2011
Ubicación: Bogota D.C
Mensajes: 793
Antigüedad: 8 años, 4 meses
Puntos: 76
Respuesta: Recibir varios post con el mismo nombre ayud!!!

y como tienes el codigo html
  #3 (permalink)  
Antiguo 12/10/2012, 09:10
Avatar de abimaelrc
Colaborador
 
Fecha de Ingreso: mayo-2009
Ubicación: En el planeta de Puerto Rico
Mensajes: 14.734
Antigüedad: 10 años, 4 meses
Puntos: 1516
Respuesta: Recibir varios post con el mismo nombre ayud!!!

Lo que tienes que hacer es usar array en los campos, algo como
Código PHP:
Ver original
  1. <input type="text" name="foo[]" />
  2. <input type="text" name="foo[]" />
  3. <input type="text" name="foo[]" />
  4. <input type="text" name="foo[]" />
  5. <input type="text" name="foo[]" />
  6. <input type="text" name="foo[]" />
  7. <input type="text" name="foo[]" />
  8. <input type="text" name="foo[]" />
  9. <input type="text" name="foo[]" />
  10. <input type="text" name="foo[]" />
Y cuando lo vayas a leer solo tienes que hacer algo como
Código PHP:
Ver original
  1. foreach($_POST['foo'] as $k => $v){
  2.     echo $k . ' ' . $v . '<br />';
  3. }
__________________
Verifica antes de preguntar.
Los verdaderos amigos se hieren con la verdad, para no perderlos con la mentira. - Eugenio Maria de Hostos

Etiquetas: mysql, nombre, post, recibir, sql, usuarios
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

SíEste tema le ha gustado a 1 personas




La zona horaria es GMT -6. Ahora son las 03:28.