Foros del Web » Programando para Internet » PHP »

Descargas Seguras (uso de memoria?)

Estas en el tema de Descargas Seguras (uso de memoria?) en el foro de PHP en Foros del Web. Hola Buscando información sobre sistemas tipo rapidshare me encontr con esto: http://sentidoweb.com/2006/10/02/des...diante-php.php Código PHP:      <?     $dir = "/path/directorio/" ;     if (isset( $_REQUEST [ "fichero" ])) {  ...
  #1 (permalink)  
Antiguo 18/07/2008, 01:23
 
Fecha de Ingreso: febrero-2002
Ubicación: Chile
Mensajes: 1.573
Antigüedad: 22 años, 2 meses
Puntos: 2
Descargas Seguras (uso de memoria?)

Hola

Buscando información sobre sistemas tipo rapidshare me encontr con esto:

http://sentidoweb.com/2006/10/02/des...diante-php.php

Código PHP:
    <? 
   $dir
="/path/directorio/"
   if (isset(
$_REQUEST["fichero"])) { 
   
$fichero=$dir.$_REQUEST["fichero"]; 
   
header("Content-type: application/force-download"); 
   
header("Content-Transfer-Encoding: Binary"); 
   
header("Content-length: ".filesize($fichero)); 
   
header("Content-disposition: attachment; filename=\"".basename($fichero)."\""); 
   
readfile("$fichero"); 
   } else { 
   echo 
"Fichero seleccionado"
  
 } 
 
?>
Mi pregunta és.
¿Como trabaja esto?
Si tengo un Archivo de 600M,¿ lo lee a memoria ese PHP y lo envia por el navegador?.. o directamente manda el nombre del archivo "por debajo" al navegador para que lo descargue?.

¿Es tan eficiente como una descarga directa a traves del server http?
¿Sera mejor crear URLS dinamicas y controlar mediante otro tipo de software la descarga de archivos? (leyendo el log file, limitando por IP, etc.)



Saludos y gracias
  #2 (permalink)  
Antiguo 18/07/2008, 04:06
 
Fecha de Ingreso: mayo-2005
Mensajes: 188
Antigüedad: 18 años, 11 meses
Puntos: 6
Respuesta: Descargas Seguras (uso de memoria?)

Lo primero: ¡VALIDA LA ENTRADA! Tal y como está ese código es MUY inseguro !!

Cita:
Iniciado por NRLABS Ver Mensaje
Mi pregunta és.
¿Como trabaja esto?
Si tengo un Archivo de 600M,¿ lo lee a memoria ese PHP y lo envia por el navegador?.. o directamente manda el nombre del archivo "por debajo" al navegador para que lo descargue?.
La función readfile() envía el contenido del fichero que le pases al navegador. Si le enviases el nombre y fuese el navegador quien se lo descargara, habrías perdido todo el control sobre la descarga.

Cita:
Iniciado por NRLABS Ver Mensaje
¿Es tan eficiente como una descarga directa a traves del server http?
¿Sera mejor crear URLS dinamicas y controlar mediante otro tipo de software la descarga de archivos? (leyendo el log file, limitando por IP, etc.)
No es tan eficiente, pero si quieres controlar las descargas, no conozco otra manera.

Saludos
  #3 (permalink)  
Antiguo 18/07/2008, 05:51
 
Fecha de Ingreso: julio-2008
Mensajes: 85
Antigüedad: 15 años, 9 meses
Puntos: 2
Respuesta: Descargas Seguras (uso de memoria?)

He estado buscando un documento que leí hace tiempo pero no hay forma de encontrarlo. Era una comparativa de las peticiones por segundo que puedes servir con readfile por un lado, y por el otro con la petición servida por el servidor http directamente.

La diferencia era bastante bestia, del orden de 1:10 creo recordar.
Pero como te dicen si quieres controlarlas no hay otro remedio.

Aun así, el servidor lighttpd de la versión 1.5.0(aun no estable) en adelante, tiene una opción muy muy interesante para hacer eso mismo sin tener que usar readfile, tan solo mandando una cabecera.
  #4 (permalink)  
Antiguo 18/07/2008, 12:18
 
Fecha de Ingreso: febrero-2002
Ubicación: Chile
Mensajes: 1.573
Antigüedad: 22 años, 2 meses
Puntos: 2
Respuesta: Descargas Seguras (uso de memoria?)

Muchas gracias por las respuestas.

Efeciivamente esto es lo que queria http://trac.lighttpd.net/trac/wiki/D...ModSecDownload

El servidor, tengo suerte que es dedicado asi que veré que implementar.

Saludos
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:32.