Hoy en día se ha vuelto una necesidad poder publicar los resultados de los análisis analíticos o los modelos de aprendizaje automático en la web. Tanto en forma de servicio web como de aplicación. Los usuarios de R cuentan para ellos con Shiny, los de Python cuentan con diferentes frameworks y los de Matlab con las posibilidades de App Designer. En el caso de Julia contamos con Genie para ellos. Genie es un framework para la creación de soluciones web basado en el patrón MVC (Modelo Vista Controlador).
Instalación de Genie
Genie no viene por defecto en Julia, por lo que para poder usarlo es necesario instalarlo. El proceso de instalación es similar al que hemos visto con otros paquetes, es necesario cargar el paquete Pkg y llamar al método add()
con 'Genie'
como opción.
¡Hola mundo! con Genie
Generalmente una de las primeras cosas que se hacen con un nuevo lenguaje o framework es crear el programa “¡Hola Mundo!”. En este caso se puede crear una página con el mensaje simplemente con el siguiente código.
using Genie, Genie.Router route("/") do "¡Hola mundo!" end up()
En la primera línea de este ejemplo se importa la librería que necesitamos: Genie
y Genie.Route
. Posteriormente se llama a la función route()
(la cual se encuentra en Genie.Route
) para indicar la ruta en la que servirá nuestro mensaje. En este caso la raíz del servidor. A lo que sigue una función en la que se creará el resultado, en este caso una cadena de texto estática con el mensaje “¡Hola mundo!”.
Finalmente solamente hay que escribir up()
para levantar nuestra primera aplicación web creada con Genie. Ahora solo hay que abrir un navegador y escribir la dirección http://localhost:8000/
, apareciendo una página en blanco con el mensaje.
Exportando los resultados en diferentes formatos
En la sección anterior se ha creado una aplicación web que devuelve un mensaje. Pero puede ser que necesitemos devolver los resultados en otro formato, como puede ser JSON. Para esto es necesario cargar las funciones de renderizado. Así se puede crear una serie de servicios con el siguiente código.
using Genie, Genie.Router using Genie.Renderer, Genie.Renderer.Html, Genie.Renderer.Json route("/text") do respond("¡Hola mundo!", :text) end route("/html") do html("¡Hola mundo!") end route("/json") do json("¡Hola mundo!") end up(3000, async = false)
En este ejemplo se ha cargado, además de lo visto en la sección anterior: Genie.Renderer
, Genie.Renderer.Html
y Genie.Renderer.Json
. Lo que nos permite generar respuestas, respuestas genéricas, en formato HTML y JSON respectivamente.
El método respond()
es un método genérico con el que se puede enviar cualquier tipo de respuesta simple con un tipo MINE. Algunos de los tipos más utilizados son: :text
, :xml
, :markdown
o :javascript
.
Por otro lado, como se puede ver en el ejemplo, para responder con una página web o un archivo JSON se puede usar las funciones html()
y json()
respectivamente.
La función up()
admite como parámetro el puerto en el que se publica la aplicación. Por defecto es 8000, pero podemos indicar que esta se publique en el puerto 3000 como es el caso. Además, se le puede indicar al servidor que este se ejecute de forma síncrona o asíncrona. Para que el código siga funcionando después de su ejecución es necesario indicar la opción async = false
.
Métodos GET y POST
A la hora de crear la ruta no se ha indicado hasta ahora qué método se usa, un método GET, un método POST o cualquier otro. Para esto se puede utilizar la opción method
de la función route()
, a la que se le puede pasar el nombre del método. Valor que por defecto es GET. Por ejemplo, para indicar que se use un método POST simplemente se tiene que usar la siguiente ruta.
route("/", method = POST) do "Método POST" end
Obtener los parámetros
Los métodos vistos hasta ahora siempre devuelven el mismo resultado ya que nunca se han pasado parámetros a las funciones. Los parámetros se pueden obtener con el método getpayload()
al que se le ha de pasar como primer valor el nombre de parámetro y como segundo el valor. Así para leer la opción nombre de la URL se puede usar
using Genie, Genie.Router, Genie.Requests route("/hola") do name = getpayload(:nombre, "Analytics Lane") "¡Hola $name!" end
Lo que devolverá “¡Hola Analytics Lane!” para la URL http://localhost:8000/hola
. Mientras que si se pasa una cadena de texto en el parámetro nombre
devolverá este, Por ejemplo, para http://localhost:8000/hola?nombre=Daniel
devolverá “¡Hola Daniel!”
Obtener el cuerpo
Otra opción es obtener los parámetros del cuerpo del mensaje. Lo que se pude obtener mediante la función postpayload()
, la cual función igual que la anterior
using Genie, Genie.Router, Genie.Requests route("/hola", method = POST) do name = postpayload(:nombre, "Analytics Lane") "¡Hola $name!" end
Genie, un método para crear aplicaciones con Julia
Hemos visto la base de Genie, un framework que podría dar lugar a una serie como esta. Ya que ofrece múltiples posibilidades para publicar aplicaciones web creadas con Julia. Permitiendo publicar nuestro trabajo de una forma que sea fácilmente accesible.
Publicaciones de la serie ¡Hola Julia!
- ¡Hola Julia!
- Primeros pasos con Julia
- Cadenas de texto en Julia
- Bucles en Julia
- Funciones en Julia
- Vectores, tuplas y diccionarios en Julia
- Estructuras en Julia
- Utilizar los tipos en Julia
- Tipos de datos en Julia
- Tipos y funciones paramétricos en Julia
- Introducción a los DataFrames en Julia
- Obtener información básica de los DataFrames de Julia
- El tipo de dato Missing de Julia
- Columnas en DataFrames de Julia
- Filas en DataFrames de Julia
- Combinar DataFrames en Julia
- Guardar y leer archivos CSV en Julia
- Guardar y leer archivos Excel en Julia
- Introducción a Genie
- Libros sobre Julia
Deja una respuesta