Ir al contenido principal

Laravel 5Subir archivos con Laravel 5

En esta entrada vamos a ver cómo subir archivos con Laravel 5, de paso repasaremos algunos otros temas, enrutar controladores, crear modelos y definir algunas de sus propiedades, utilizar blade y su sistema de herencia y cómo guardar el registro del archivo en base de datos comprobando el tipo de extensión.
Antes de comenzar debemos recordar que para utilizar las clases HTML y FORM en laravel 5 debemos hacer la instalación con composer, a continuación dejo una entrada donde puedes revisar un poco más en profundidad sobre este tema.

Añadir las clases Html y Form en Laravel 5

Simplemente debemos añadir la siguiente línea al archivo composer.json, justamente en la clave require.

Ahora para que las dependencias se instalen ejecuta el siguiente comando situado en tu proyecto.

Abre el archivo config/app.php y añade las siguientes líneas a sus respectivos arrays, primero al providers y después al aliases.

Configurar la conexión a base de datos

Recuerda que el encargado de comunicar los datos de conexión a nuestra aplicación en laravel 5 es el archivo .env que tenemos en la raíz, por lo menos así es por defecto, así que recuerda poner tus datos.

Crear el controlador UploadsController

Para crear nuestro controlador simplemente ejecuta el siguiente comando desde la terminal situado en tu proyecto.

Enrutar nuestro controlador en Laravel 5

Enrutar un controlador en laravel 5 es muy sencillo, simplemente debemos ir a nuestro archivo app/Http/routes.php y añadir la siguiente lína.

De esta forma, nuestro controlador UploadsController ya habrá sido mapeado correctamente.

Crear la tabla uploads

Sabemos que laravel 5 nos ofrece la posibilidad de trabajar con migraciones para llevar un control de versiones de nuestra base de datos, pero también sabemos que esto no es obligatorio, así que aquí dejo el sql de la tabla uploads, simplemente genera la tabla con ese código.

Crear el modelo Upload

Para crear el modelo que se va a comunicar con nuestra tabla uploads ejecuta el siguiente comando en la terminal.

Ese comando habrá generado un archivo llamado Upload.php en el directorio app, ábrelo y añade el siguiente código.

Una característica importante de este modelo es ver cómo deshabilitamos los timestamps, así Eloquent no seteará created_at ni updated_at.
Ahora abre el controlador UploadsController y añade el método index para renderizar la vista del formulario.

Antes de seguir con la generación del formulario, crea un archivo llamado master.blade.php en el directorio resources/views y añade el siguiente código.

Simplemente definimos varias secciones y damos unos estilos al botón para subir archivos.
Ahora sí, crea el directorio uploads en resources/views y dentro el archivo form.blade.php con el siguiente código.

Es importante darse cuenta que para poder subir archivos necesitamos establecer la propiedad files a true en el método open de nuestro formulario.

Procesar archivos con Laravel 5

Ahora ya podemos procesar el formulario y crear el registro en base de datos, para ello simplemente añade el siguiente método en nuestro controlador UploadsController.

Antes de explicar este método, ya sabemos que podemos crear nuestros formularios y validarlos con la clase Request en Laravel 5.
Lo primero que hacemos es comprobar que se ha enviado el campo file, en otro caso devolvemos un mensaje diciendo que ese campo es obligatorio.
Después obtenemos la extensión, el mimetype y creamos un nombre para el archivo.
Si tienes problemas a la hora de obtener el mimetype asegúrate que tienes cargada la extensión php_fileinfo en tu php.ini.
En nuestro caso sólo permitimos subir archivos jpg, png, gif y pdf, en otro caso no procesamos el archivo ni el modelo, sino que redirigimos al formulario con un mensaje de error.
Finalmente, comprobamos si el archivo ha subido correctamente, (recuerda crear el directorio files_uploaded dentro de public) con el método isValid(), si ha subido, lo movemos al directorio final y generamos un registro en base de datos relacionado con el archivo subido, al final redirigimos a la vista del formulario con un mensaje satisfactorio.

Comentarios

Entradas populares de este blog

12 Razones para usar Kotlin en tu proximo proyecto Android.

1. El lenguaje y el entorno están maduros A diferencia de otros lenguajes como Swift, el lanzamiento de  Kotlin ha pasado por muchas etapas de maduración antes de liberar la versión 1.0 final . Esto quiere decir que no vas a encontrarte problemas al trabajar con Kotlin, todo funciona como cabría esperar. El plugin del IDE funciona perfectamente , y ya permite muchas de las funcionalidades que existen para Java. Por ello, trabajar con Kotlin es un maravilla en ese sentido. Es interesante saber que antes de salir a producción, el lenguaje pasó varios años en alpha y luego en beta, y que ya antes de que saliera la beta había gente que lo estaba utilizando en proyectos reales. 2. Facilita mucho el desarrollo en Android Si has estado leyendo todos estos artículos, lo habrás visto claro en muchas ocasiones. Kotlin es simplicidad mezclada con potencia , por lo que tienes un mundo abierto de posibilidades si venías de Java que antes ni podías imaginar. Sinceramente creo que

Comparación de diferentes clientes que pueden realizar una petición http (file-get-contents, curl, guzzle ybuzz).

Para un proyecto que vamos a comenzar dentro de la compañía, y para el cual el rendimiento es muy importante, hemos realizado una comparación entre diferentes clientes que pueden realizar una petición http. Nuestra idea original era usar guzzle, pero como digo el rendimiento es importante, por lo que antes de usarlo, decidimos realizar algunos test de rendimiento. Los requisitos que tiene que cumplir nuestro cliente son: Poder comprobar códigos de estado en las respuestas. Gestión avanzada de cabeceras ( petición y respuesta ). Poder configurar timeouts. En la medida de lo posible, que sea rápido y consuma poca memoria. Las pruebas se realizadan contra un servidor local, el código para las pruebas es este. <?php /* * This file is part of the XXX package. * * (c) Daniel González <daniel@desarrolla2.com> * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ require __DIR__.&#