Foros del Web » Programando para Internet » PHP »

descargar archivo que esta en un campo en la DB

Estas en el tema de descargar archivo que esta en un campo en la DB en el foro de PHP en Foros del Web. Hola mi prugunta es esta, como puedo descargar un archivo que fue subido a la base de datos? Tengo una pagina con un formulario dnd ...
  #1 (permalink)  
Antiguo 18/06/2013, 16:18
 
Fecha de Ingreso: junio-2009
Mensajes: 36
Antigüedad: 14 años, 10 meses
Puntos: 0
descargar archivo que esta en un campo en la DB

Hola mi prugunta es esta, como puedo descargar un archivo que fue subido a la base de datos? Tengo una pagina con un formulario dnd el usuario pone sus datos y adjunta un archivo, al presionar submit se inserta la info en la DB y se sube le archivo a un campo en llamado "content", aqui esta el codigo de esa funcion de esa pagina:


Código PHP:
 function send(){
            
                
$result mysql_query('SELECT FWTC FROM inno_project ORDER BY FWTC DESC LIMIT 1;');
                if (
mysql_num_rows($result) > 0) {
                
$uno 1;
                
$code mysql_fetch_row($result);}
            
            if(isset(
$_POST['upload'])&&$_FILES['userfile']['size']>0)
                {
                    
$client $_POST['client'];
                    
$requestorName $_POST['requestorName'];
                    
$firewallName $_POST['firewallName'];
                    
                    
$implementationDate $_POST['implementationDate'];

                    
$fileName $_FILES['userfile']['name'];
                    
$tmpName  $_FILES['userfile']['tmp_name'];
                    
$fileSize $_FILES['userfile']['size'];
                    
$fileType $_FILES['userfile']['type'];
                    
$fileType=(get_magic_quotes_gpc()==mysql_real_escape_string(
                    
$_FILES['userfile']['type']) : mysql_real_escape_string(
                    
stripslashes ($_FILES['userfile'])));
                    
$fp      fopen($tmpName'r');
                    
$content fread($fpfilesize($tmpName));
                    
$content addslashes($content);
                    
fclose($fp);
                    if(!
get_magic_quotes_gpc())
                            {
                                
$fileName addslashes($fileName);
                }
                    
                        
$db mysql_select_db('project_db');
                        if(
$db){
                        
$FWTC $code[0] + $uno;
                        
$query "INSERT INTO inno_project (FWTC, Client, Requestor_Name, Firewall_Name, Implementation_Date, file_name, file_size, file_type, content ) ".
                        
"VALUES ('$FWTC', '$client', '$requestorName', '$firewallName', '$implementationDate', '$fileName', '$fileSize', '$fileType', '$content')";
                        
mysql_query($query) or die('Invalid query: ' mysql_error() 
); 
                        
mysql_close();
                        
//echo $code[0];
                        
echo "The request uploaded successfully, your request code is: ";
                        echo 
$FWTC;
                        
//echo "<br>Request $fileName uploaded<br>";
                        
}else { echo "Request upload failed!"; }
    }
            
            
            
            } 

Hasta ahi todo bien, ahora tengo este otro codigo dnd otra persona puede ver la info de cualquier formulario subido por cualquier otro usuario poniendo el numero de ID en un text box, lo que necesito es que cuando digite y envie el numero de ID para ver la informacion de cualquier formulario tambien me de un link para descargar el archivo correspondiente a ese ID que esta en la DB.

Código PHP:
<?php
    
include_once 'func.php';
    
connect();
    

  
$input $_POST["id"];
  
$query mysql_query("SELECT * FROM inno_project where FWTC = $input");
  
//$result=mysql_query($query);
  
$rows=mysql_fetch_array($query);

if (!
$rows) {
    die(
'Invalid query: ' mysql_error());
}
    
else{    
    echo 
$rows['Requestor_Name'];
    echo 
$rows['Client'];
    echo 
$rows['Firewall_Name'];
    echo 
$rows['Implementation_Date'];
    echo 
$rows['file_name'];
    
//echo $rows['content'];
    
    
    
}



?>
Necesito algo asi como un "echo" que me de el link de descarga del archivo que corresponde al ID introducido en el text box . La info del formulario si la obtengo bien pero no se como hacerle para descargar el archivo.

Última edición por oscarza; 18/06/2013 a las 16:44
  #2 (permalink)  
Antiguo 19/06/2013, 00:18
Avatar de repara2  
Fecha de Ingreso: septiembre-2010
Ubicación: München
Mensajes: 2.445
Antigüedad: 13 años, 7 meses
Puntos: 331
Respuesta: descargar archivo que esta en un campo en la DB

Si has guardado el contenido del archivo en un campo (creo que has hecho eso), entonces tendrás que hacer echo o algo así. Otra opción es poner un link que realice una segunda consulta que descargará el archivo. Igual no entiendo mucho lo que has hecho, saludos.
__________________
Fere libenter homines, id quod volunt, credunt.
  #3 (permalink)  
Antiguo 19/06/2013, 11:10
 
Fecha de Ingreso: junio-2009
Mensajes: 36
Antigüedad: 14 años, 10 meses
Puntos: 0
Respuesta: descargar archivo que esta en un campo en la DB

Hola, ya he logrado avanzar, tengo este codigo que me muestra el link para la descarga del archivo tipo blob que esta en un campo en la DB, el link hace referencia al archivo php que procesa la descarga que se llama descarga_archivo.php:

Código PHP:
<?php
                    $qry 
"SELECT file_name, file_type, content FROM inno_project where FWTC = $input";
                    
$res mysql_query($qry);
                    while(
$fila mysql_fetch_array($res))
                    {
                        echo 
"$fila[file_name] ($fila[file_type]) <br/>";
                        echo 
"<a href='descargar_archivo.php?id=$fila[content]'>Descargar</a>";
                    }
                
?>

Este es el codigo del archivo descargar_archivo.php:

Código PHP:
<?php
 $extenciones 
= array("application/vnd.ms-excel"=>"xls""application/msword"=>"doc",
 
"application/vnd.openxmlformats-officedocument.wordprocessingml.document");
 
$qry "SELECT file_type, content, file_name FROM inno_project WHERE FWTC = $input";
 
$res mysql_query($qry);
 
$tipo mysql_result($res0"file_type");
 
$contenido mysql_result($res0"content");
 
$nombre mysql_result($res0"file_name");
 
header("Content-type: $tipo");
 
header('Content-disposition: attachment; filename="'.$nombre.'.'.$extenciones[$tipo].'"');
 print 
$contenido
?>
Lo que pasa es que al darle click al link para que me descage el archivo me envia a una pagina que dice algo como "URI is too long", al parecer envia el contenido del archivo a la URL en vez de enviarlos para descargarlo, necesito algo de ayudaa ver que ven del mal en mi codigo por favor!
  #4 (permalink)  
Antiguo 19/06/2013, 16:07
(Desactivado)
 
Fecha de Ingreso: julio-2006
Mensajes: 273
Antigüedad: 17 años, 9 meses
Puntos: 5
Respuesta: descargar archivo que esta en un campo en la DB

Lo mejor seria que guardaras un archivo fisico en una carpeta de tu sistema, y luego colocas la ruta en donde esta el archivo por ejemplo documentos/archivo.xls.

solo lo llamas y listo.
  #5 (permalink)  
Antiguo 19/06/2013, 16:50
 
Fecha de Ingreso: junio-2009
Mensajes: 36
Antigüedad: 14 años, 10 meses
Puntos: 0
Respuesta: descargar archivo que esta en un campo en la DB

Cita:
Iniciado por eduardo90 Ver Mensaje
Lo mejor seria que guardaras un archivo fisico en una carpeta de tu sistema, y luego colocas la ruta en donde esta el archivo por ejemplo documentos/archivo.xls.

solo lo llamas y listo.
y como podria hacer eso, tienes algun link o referencia que me recomiendes?
  #6 (permalink)  
Antiguo 20/06/2013, 01:03
Avatar de repara2  
Fecha de Ingreso: septiembre-2010
Ubicación: München
Mensajes: 2.445
Antigüedad: 13 años, 7 meses
Puntos: 331
Respuesta: descargar archivo que esta en un campo en la DB

echo "<a href='descargar_archivo.php?id=$fila[content]'>Descargar</a>";

no será id=$fila[id] o similar?
__________________
Fere libenter homines, id quod volunt, credunt.

Etiquetas: campo, formulario, mysql, select, sql
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 08:26.