La imagen se sube a la carpeta pero no sube nada a la base de datos

Iniciado por EdwardX, 28 Agosto 2016, 23:51 PM

0 Miembros y 1 Visitante están viendo este tema.

EdwardX

¿Demasiado complicado? Ya intentaré preguntar en otros foros a ver si alguien sabe. ¿Me recomendáis algún foro de php?

Saludos y gracias de todos modos. ; )
Aprendiz eterno

.rn3w.

no pude leer todo el post, pero donde esta la variable del directorio?


EdwardX

¡Gracias una vez más por la respuesta!
¿Te refieres a esto?
$carpeta = "imagenesdiscos/";

La imagen se guarda en la carpeta, pero no se como publicarla utilizando ruta guardada en base de datos.

El objetivo del proyecto es el siguiete:

1)Un formulario que permita a los usuarios publicar en una web discos de jazz locales introduciendo los siguientes valores:
-Título del disco
-Año de publicación
-Sello discográfico
-Títulos de los temas (de las canciones)
-Nombres de los músicos que han formado parte del disco
-Comentario sobre el disco
-Imagen de la portada del disco de tamaño: 500px X 500px
(Este último es el que me da problemas)

2)En una sección llamada Discos se verás todos los discos publicados por la gente.


Éxitos y Fracasos:

Éxitos: Todos los datos de texto se introducen en la base de datos perfectamente y se publican. La imagen de la carátula se sube al directorio.
Fracasos: No consigo que se publiquen las carátulas de los discos subidos en el formulario. Se suben a la carpeta local, y nada más... ¡Socorro! ; )


¿A alguien se le ocurre cómo hacerlo?

¡Muchas gracias a todos!
Aprendiz eterno

#!drvy

Por favor, no hagas doble post. Este es el sitio adecuado para tu pregunta puesto que estas utilizando PHP.

Tu problema es de lo mas simple. Como te dije en el principio, ignorabas la octava variable que le pasabas a la query y por eso no se subía nada, para solucionarlo, en vez de darle a la query esa variable decidiste quitarla del set. Obviamente si la quitas nunca la subirás.

Tu problema es la lógica que le aplicas. Ya no es por decir nada pero esto es un caso muy simple al que no le estas prestando atención.

Código (php) [Seleccionar]
$carpeta = 'imagenesdiscos/';
$destino = $carpeta.$_FILES['imagendisco']['name'];

if(copy($_FILES['imagendisco']['tmp_name'],$destino)){
   $nombreImagen=$_FILES['imagendisco']['name'];  
}

$consulta = mysql_query("INSERT INTO discos(titulo,artista,ano,sello,temas, artistas,comentario,fotodisco) VALUES ('$titulodisco','$grupoartista','$anopublicacion','$sello','$titulostemas','$musicosdisco','$comentariodisco', '$nombreImagen')");

if($consulta){
   echo "Error al insertar los datos en la tabla. ". mysql_error();
} else {
   echo "Correcto."
}



Abrir un iterador de directorio es inutil en este caso y menos como lo estas haciendo.
http://www.php.net/opendir

Alteras el uso de comillas dobles y simples sin sentido alguno y el tabbing parece inconsistente. A mi lo que me parece es que has intentado copiar código de por ahí y no te sale lo que querías... pero que tampoco te has esforzado mucho en deducir porque..

Saludos

EdwardX

¡Muchas gracias #!drvy!
Efectivamente soy un novato. Revisaré e intentaré comprender el código. A ver si lo consigo... Parte del código como bien deducez lo he ido añadiendo mirando y copiando por aquí y por allá, ya que soy aprendiz. Algunas cosas comprendiendo y otras que todavía no. Aunque hasta hace poco me he dedicado más al diseño que al backend, me interesa mucho y trato de aprender php y bases de datos poco a poco. Espero no dar mucho la lata. xD

Saludos y gracias. ; )
Aprendiz eterno

EdwardX

Me da el siguiente error: "Error al insertar los datos en la tabla."  :xD

¿Es correcto esto? Esto de que tenga 2 destinos no lo entiendo bien. ¿Es uno para la imagen física y lo otro para el temporal?
Código (php) [Seleccionar]

$fotodisco = $_FILES["imagendisco"]['tmp_name'];






Código (php) [Seleccionar]
//CONEXION//
<?php
$conexion mysql_connect("localhost""jazzgune","XXXXXX");
if(!isset($conexion)){
echo "Error al conectar a la base de datos." mysql_error();
mysql_error();
exit();
}
//SELECCION DE BASE DE DATOS//
$seleccionar_bd mysql_select_db("jazzgune");
if(!isset($seleccionar_bd)){
echo "Error al seleccionar la base de datos." mysql_error();
exit();
}

//DE FORMULARIO A VARIABLE//
$titulodisco $_POST["titulodisco"];
$grupoartista $_POST["grupoartista"];
$anopublicacion $_POST["anopublicacion"];
$sello $_POST["sello"];
$titulostemas $_POST["titulostemas"];
$musicosdisco $_POST["musicosdisco"];
$comentariodisco $_POST["comentariodisco"];
$fotodisco $_FILES["imagendisco"]['tmp_name'];




//INSERTAR DE VARIABLE A TABLA DE BASE DE DATOS//
    
$carpeta 'imagenesdiscos/';
    
$destino $carpeta.$_FILES['imagendisco']['name'];
     
    if(
copy($_FILES['imagendisco']['tmp_name'],$destino)){
        
$nombreImagen=$_FILES['imagendisco']['tmp_name'];   
    }
     
//DE 8 ELEMENTOS A 8 ELEMENTOS...//
    
$consulta mysql_query("INSERT INTO discos(titulo,artista,ano,sello,temas, artistas,comentario,fotodisco) VALUES ('$titulodisco','$grupoartista','$anopublicacion','$sello','$titulostemas','$musicosdisco','$comentariodisco','$nombreImagen')");
     
    if(
$consulta){
        echo 
"Error al insertar los datos en la tabla. "mysql_error();
    } else {
        echo 
"Correcto.";
    }

?>



¡Un saludo y gracias!  ;-)
Aprendiz eterno

EdwardX

¡Ya sube el nombre del archivo a la base de datos y la imagen a la carpeta indicada! Parece que la cosa avanza... xD
Pero sale el error aunque funcione...
"Error al insertar los datos en la tabla. "

¡Saludos!
Aprendiz eterno

EdwardX

Tengo dudas de cómo se debería poner la sintaxis en el caso de tener:
php +html + php + html + php
(Como lo indicado en negrita)


<?php
   include("conexion.php");
   $consulta = mysql_query("SELECT * FROM discos");
   
   while ($registro = mysql_fetch_array ($consulta)) {
      echo "<img src='imagenesdiscos/'.$registro['fotodisco']./>";

?>
Aprendiz eterno

.rn3w.

deberia ser asi

if(!$consulta){
        echo "Error al insertar los datos en la tabla. ". mysql_error();
    } else {
        echo "Correcto.";
    }

#!drvy

Efectivamente, se me escapo un ! delante de $consulta. Pero tampoco te molestaste en mirar el código :/

Saludos