Foros del Web » Programando para Internet » PHP »

Subir Fichero CSV con boton Examinar

Estas en el tema de Subir Fichero CSV con boton Examinar en el foro de PHP en Foros del Web. Muy buenas tengo que subir un fichero al servidor para su leerlo y meter el contenido en una matriz, utilizo un boton Examinar y me ...
  #1 (permalink)  
Antiguo 01/06/2009, 05:56
 
Fecha de Ingreso: agosto-2007
Mensajes: 248
Antigüedad: 16 años, 7 meses
Puntos: 1
De acuerdo Subir Fichero CSV con boton Examinar

Muy buenas tengo que subir un fichero al servidor para su leerlo y meter el contenido en una matriz, utilizo un boton Examinar y me gustaría saber las comprobaciones previas que debo hacer para subir un fichero al servidor con PHP.

A mi en un principio me salen 3 que son las siguientes:

a) Debe logicamente subirse un fichero. Funcion "is_uploaded_file"
b) Tamaño (en mi caso no debe superar los 2 megas)
c) Extension (en mi caso debe ser CSV)

Os pongo el codigo que me sale

<input id="ficherodevolucion" name="ficherodevolucion" type="file" size="47" maxlength="150" onkeyup="es_vacio();"/>


//2MB = 2048KB Establece el tamaño maximo del fichero subido || php.ini MAX_FILE_SIZE = 2M
$maxsize=2097152;
$nombre_fichero = $_FILES['ficherodevolucion']['name'];
$tipo_fichero = $_FILES['ficherodevolucion']['type'];
$tamanyo_fichero = $_FILES['ficherodevolucion']['size'];
$nombre_tmp = $_FILES['ficherodevolucion']['tmp_name']; /*C:/windows/temp*/

//1A. ¿Se ha enviado algun fichero?.
if (!(is_uploaded_file($_FILES['ficherodevolucion']['tmp_name'])))
{
echo 'Debe subir un fichero';
unlink($_FILES['ficherodevolucion']['tmp_name']); //Elimina un archivo
exit; //Forzamos salida
}

//1B. ¿Es demasiado grande?. Tamaño del fichero
if ($_FILES['ficherodevolucion']['size'] > $maxsize)
{
echo 'Error, el fichero supera la capacidad permitida';
unlink($_FILES['ficherodevolucion']['tmp_name']); //Elimina un archivo
exit; //Forzamos salida
}

//1C. Comprobacion de la extension del Fichero (SOLO CSV)
if($_FILES['ficherodevolucion']['type'] != "application/vnd.ms-excel")
{
echo 'El fichero no tiene una extension valida. Debe ser CSV.';
unlink($_FILES['ficherodevolucion']['tmp_name']); //Elimina un archivo
exit; //Forzamos salida
}

copy($_FILES['ficherodevolucion']['tmp_name'],"./fich_dev/".$_FILES['ficherodevolucion']['name']);
echo 'Gracias por la subida'.'<br/><br/>';
echo $nombre_fichero.'<br/><br/>';
echo $tipo_fichero.'<br/><br/>';
echo $tamanyo_fichero.'<br/><br/>';
echo $nombre_tmp.'<br/><br/>';
exit;


Gracias ¡¡¡
  #2 (permalink)  
Antiguo 01/06/2009, 11:37
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 17 años, 10 meses
Puntos: 2135
Respuesta: Subir Fichero CSV con boton Examinar

¿Cual es la pregunta?

Saludos.
  #3 (permalink)  
Antiguo 02/06/2009, 01:01
 
Fecha de Ingreso: agosto-2007
Mensajes: 248
Antigüedad: 16 años, 7 meses
Puntos: 1
Respuesta: Subir Fichero CSV con boton Examinar

La pregunta es clara y concisa:

¿Cuáles son las comprobaciones previas que debo hacer para subir un fichero al servidor con PHP?
  #4 (permalink)  
Antiguo 02/06/2009, 07:26
Avatar de abimaelrc
Colaborador
 
Fecha de Ingreso: mayo-2009
Ubicación: En el planeta de Puerto Rico
Mensajes: 14.734
Antigüedad: 14 años, 10 meses
Puntos: 1517
Respuesta: Subir Fichero CSV con boton Examinar

En realidad tu vas descubriendo las condiciones mientras vas creando el codigo y haciendo prueba. Pero mientras tanto lo que tienes es lo que yo pensaria por el momento.
  #5 (permalink)  
Antiguo 02/06/2009, 11:28
 
Fecha de Ingreso: agosto-2007
Mensajes: 248
Antigüedad: 16 años, 7 meses
Puntos: 1
De acuerdo Respuesta: Subir Fichero CSV con boton Examinar

¿Pero me podeis dar alguna idea que se os ocurra para validar el fichero?

Gracias ¡¡
  #6 (permalink)  
Antiguo 02/06/2009, 12:07
Avatar de abimaelrc
Colaborador
 
Fecha de Ingreso: mayo-2009
Ubicación: En el planeta de Puerto Rico
Mensajes: 14.734
Antigüedad: 14 años, 10 meses
Puntos: 1517
Respuesta: Subir Fichero CSV con boton Examinar

Una alternativa puede ser que abras el archivo con fopen("archivo.xls", "r") y verifiques si sale esto

Microsoft Excel

Le di right click y ver con notepad y verifique con varios archivos excel a ver si tenian eso y sale siempre en alguna parte del archivo. Así te aseguras de que sea un archivo .xls. Pero como te indique es una alternativa. como tambien funciona lo de verificar
$_FILES['ficherodevolucion']['type'] != "application/vnd.ms-excel"

Me dejas saber
  #7 (permalink)  
Antiguo 02/06/2009, 12:09
 
Fecha de Ingreso: septiembre-2004
Mensajes: 324
Antigüedad: 19 años, 7 meses
Puntos: 13
Respuesta: Subir Fichero CSV con boton Examinar

http://es.php.net/filetype
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 18:10.