Foros del Web » Programando para Internet » PHP »

Duda imágenes tienda PHP a mano

Estas en el tema de Duda imágenes tienda PHP a mano en el foro de PHP en Foros del Web. Hola a todos: Estoy desarrollando una web de ventas en PHP (a mano, sin CMS) para aprender, y necesito un poco de ayuda. Normalme programo ...
  #1 (permalink)  
Antiguo 10/03/2013, 07:38
 
Fecha de Ingreso: diciembre-2012
Ubicación: Madrid
Mensajes: 21
Antigüedad: 12 años
Puntos: 0
Duda imágenes tienda PHP a mano

Hola a todos:

Estoy desarrollando una web de ventas en PHP (a mano, sin CMS) para aprender, y necesito un poco de ayuda. Normalme programo en Java, y ando un poco perdido.

El tema es que quiero que a la web se puedan subir una, dos o tres imágenes, como mínimo tiene que haber una, y dejar las demás vacías.

Tengo un form donde introduzco los datos de los productos, el resto son campos de texto o similar, y las imágenes van aquí:

Código PHP:
          <tr>
            <
td><strong>Imagen 1:</strong></td>
            <
td> <input name="imagen1" id="imagen1" type="file"  />
            </
td>
          </
tr>
          <
tr>
            <
td><strong>Imagen 2:</strong></td>
            <
td> <input name="imagen2" id="imagen2" type="file"  />
            </
td>
          </
tr>          
          <
tr>
            <
td><strong>Imagen 3:</strong></td>
            <
td> <input name="imagen3" id="imagen3" type="file"   />
            </
td>
          </
tr
Luego, en el código php que uso para insertar los campos en la base de datos, lo hago de la siguiente manera:

Código PHP:
if (isset($_POST['nombreProducto']))
{
    
$nombreProducto mysql_real_escape_string($_POST['nombreProducto']);
    
$descripcionProducto mysql_real_escape_string($_POST['descripcionProducto']);
    
$composicionProducto mysql_real_escape_string($_POST['composicionProducto']);
    
//$fyhIngreso = mysql_real_escape_string($_POST['fyhIngreso']); La hora se actualiza automáticamente en el insert,pero no en el update
    
$precioProducto mysql_real_escape_string($_POST['precioProducto']);
    
    
//miro si ya existe un producto con ese nombre
    
$sql mysql_query("SELECT id FROM productos WHERE nombre='$nombreProducto' LIMIT 1");
    
    
//cojo el número de filas devueltas
    
$result mysql_num_rows($sql);
    
    if (
$result 0)
    {
        echo 
'ERROR. Ya existe un producto con ese nombre. <a href="admin_nuevo_producto.php"> Volver </a>';
        exit();
    }
    
    
//inserción en la BD
    
$sql mysql_query("INSERT INTO producto (nombre, descripcion, composicion, pvp) VALUES ($nombreProducto, $descripcionProducto, $composicionProducto, $precioProducto)") or die (mysql_error());

    
$pid mysql_insert_id();
    
    
    
//meter la imagen en la carpeta:
    
$nombreImagen "$pid.jpg";
    
move_uploaded_file($_FILES['imagen1']['tmp_name'], "../imagenes/$categoria/$nombreImagen");
}
?> 
Lo que hago es guardar en una carpeta las imágenes con el id de la insert de la BD como nombre de las imágenes, pero esto solo me vale para la primera imagen, como puedo hacer lo siguiente?:

1) poner un if para ver si el campo de la imagen2 está vacío y si NO está vacío que la guarde como el nombre del pid seguido por un 2 .jpg:
$nombreImagen = "$pid2.jpg"; -> esto funciona? php lo traga?

como se haría el if para ver si el campo está vacio?

2) hacer un if anidado al anterior para la 3ª imagen compriobando si está vacía y si no: $nombreImagen = "$pid3.jpg";


teneis alguna idea mejor?

sabeis algún manual para hacer este tipo de cosas?


Muchas gracias anticipadamente a cualquier respuesta!
  #2 (permalink)  
Antiguo 10/03/2013, 08:01
Avatar de pzin
Moderata 😈
 
Fecha de Ingreso: julio-2002
Ubicación: Islas Canarias
Mensajes: 10.489
Antigüedad: 22 años, 4 meses
Puntos: 2114
Respuesta: Duda imágenes tienda PHP a mano

Lo ideal sería que en tu formulario pusieras algo así en el name:

Código HTML:
Ver original
  1. <input name="imagen[]" id="imagen1" type="file"   />

Porque luego puedes recorrer las imágenes con un foreach(). Así si no se sube más que dos imágenes, sólo vas a recorrer esas dos imágenes con el bucle.
  #3 (permalink)  
Antiguo 10/03/2013, 08:08
 
Fecha de Ingreso: diciembre-2012
Ubicación: Madrid
Mensajes: 21
Antigüedad: 12 años
Puntos: 0
Respuesta: Duda imágenes tienda PHP a mano

Cita:
Iniciado por Bonez Ver Mensaje
Lo ideal sería que en tu formulario pusieras algo así en el name:

Código HTML:
Ver original
  1. <input name="imagen[]" id="imagen1" type="file"   />

Porque luego puedes recorrer las imágenes con un [URL="http://php.net/manual/en/control-structures.foreach.php"]foreach()[/URL]. Así si no se sube más que dos imágenes, sólo vas a recorrer esas dos imágenes con el bucle.

Ok, muchas gracias.

Y como hago para que las imágenes no tengan el mismo nombre?
  #4 (permalink)  
Antiguo 10/03/2013, 08:16
Avatar de pzin
Moderata 😈
 
Fecha de Ingreso: julio-2002
Ubicación: Islas Canarias
Mensajes: 10.489
Antigüedad: 22 años, 4 meses
Puntos: 2114
Respuesta: Duda imágenes tienda PHP a mano

Cita:
Iniciado por Drummer Ver Mensaje
Ok, muchas gracias.

Y como hago para que las imágenes no tengan el mismo nombre?
Según lo que decías, puedes crear un contador que dentro del bucle que se autoincremente (con $var++;) y añades esa variable al nombre del archivo.

Etiquetas: mano, mysql, select, sql, tienda
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:00.