Foros del Web » Programando para Internet » PHP »

Forzar descarga de archivos y no ejecutarlos

Estas en el tema de Forzar descarga de archivos y no ejecutarlos en el foro de PHP en Foros del Web. Buenas noches a todos... Como ya mencione en un tema anterior creado hace unos meses, estoy desarrollando un sistema de autogestion online para una institución. ...
  #1 (permalink)  
Antiguo 14/12/2015, 22:49
 
Fecha de Ingreso: agosto-2015
Ubicación: Córdoba
Mensajes: 3
Antigüedad: 8 años, 8 meses
Puntos: 0
Pregunta Forzar descarga de archivos y no ejecutarlos

Buenas noches a todos...
Como ya mencione en un tema anterior creado hace unos meses, estoy desarrollando un sistema de autogestion online para una institución.
En el mismo los usuarios pueden subir material de estudio, es decir los profesores para que los alumnos lo descarguen, pero surge un incomveniente.
Si algún usuario sube por ejemplo un archivo .PHP y obtiene el path que tiene la URL directa del webserver y luego accedo a esa URL, en vez de descargarme el archivo, me lo ejecuta, dejando todo el sistema vulnerable y con accesos a los directorios, al código, etc...
ejemplo URL: www.dominio.com/carpeta/subcarpeta/archivo.php

Agradecería muchísimo quien me pueda brindar una solución a esto ya que me estoy volviendo loco.
Saludos a toda la comunidad.
  #2 (permalink)  
Antiguo 14/12/2015, 23:48
 
Fecha de Ingreso: julio-2011
Ubicación: Los Rios
Mensajes: 145
Antigüedad: 12 años, 9 meses
Puntos: 10
Respuesta: Forzar descarga de archivos y no ejecutarlos

Para asegurarnos que el comportamiento al clicar sobre un enlace de nuestra página web sea el esperado en la mayoría de navegadores, deberemos crear un fichero .htaccess, en el cual indicaremos lo siguiente:

Código Apache:
Ver original
  1. <FilesMatch "\.(?i:extension1|extension2)$">
  2.   ForceType application/octet-stream
  3.   Header set Content-Disposition attachment
  4. </FilesMatch>

Con esta entrada, indicaremos las extensiones que queremos forzar la descarga. En el caso de indicar varias extensiones, por ejemplo doc, docx, pdf, txt, .., deberemos separarlas con una barra vertical “|”.

Una vez creado el fichero .htaccess, lo guardaremos en la carpeta donde se ubiquen los ficheros en cuestión.

Espero haber ayudado

Fuente: evidaliahost.com

Etiquetas: 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




La zona horaria es GMT -6. Ahora son las 15:22.