Si eres un desarrollador Python y quieres comenzar a crear tus propios proyectos web, déjame decirte que puedes comenzar desde el ya si la necesidad de instalar ningún tipo de framewok o librería. ¿Cómo es esto posible? 🤔, deja te cuento.
La comunidad web Python ha creado un estándar llamado Web Server Gateway Interface, o por sus siglas, WSGI. Este standar nos permite escribir programas los cuales puedan comunicarse a través del protocolo HTTP, es decir, Internet.
WSGI se encuentra inspirado en el estándar Common Gateway Interface o CGI.
Cuando escribimos un programa siguiendo el standar SWGI dicho programa podrá ejecutarse en un servidor web tal como Apache o nginix.
Hola Mundo
Ahora vamos a crear nuestro primer Hola mundo utilizando el estándar WSGI.
from wsgiref.simple_server import make_server
def application(environ, start_response):
headers = [('Content-type', 'text/plain; charset=utf-8')]
start_response('200 OK', headers)
return ['Hola gente de códigofacilito'.encode('utf-8')]
server = make_server('localhost', 8000, application)
server.serve_forever()
Listo, con 11 líneas de código tenemos un servidor que es capaz de responder a las peticiones de diferentes clientes.
Si nosotros ejecutamos nuestro script, e ingresamos a http://localhost:8000/ a través de nuestro navegador obtendremos el siguiente resultado :
Lo primero que debemos hacer es importar la función make_server, a partir de esta función podremos generar nuestro servidor.
La función recibe tres argumentos obligatorios, La dirección del servidor, el puerto y la _función handler. La función como observamos posee dos parámetros environ y start_response.
El parametro env es un diccionarion el cual contiene variables wsgi relacionadas con la petición del cliente (Método del protocolo, Query String etc ...)
El parametro start_response es un callback el cual recibe, de forma obligatoria, dos argumentos. El estatus y los encabezados de la respuesta.
Dentro de la función definimos los encabezados de la respuesta, de igual forma indicamos el status code, en este caso 200, exito 😎, finalmente retornamos un recurso. Para este ejemplo hemos retornado un pequeño string.
Páginas web
Si nosotros así lo deseamos podemos retornar una páginas web. 😃
from wsgiref.simple_server import make_server
HTML = """
<!DOCTYPE html>
<html>
<head>
<title>Título</title>
</head>
<body>
<h1>Hola gente de códigofacilito</h1>
</body>
</html>
"""
def application(environ, start_response):
headers = [ ('Content-type', 'text/html; charset=utf-8') ]
start_response('200 OK', headers)
return [bytes(HTML, 'utf-8')]
server = make_server('localhost', 8000, application)
server.serve_forever()
Páginas dinámicas
Con la ayuda de la librería Jinja2 podemos crear páginas web dinámicas. Su integración es muy sencilla.
En esta ocasión genero un archivo .html que será nuestro template. En mi caso, el archivo lo almaceno en el folder templates.
<!DOCTYPE html>
<html lang="en" dir="ltr">
<head>
<meta charset="utf-8">
<title> {{ title }} </title>
</head>
<body>
<h1>Hola {{ username }}</h1>
</body>
</html>
Una maquetado bastante sencillo, pero funcionará.
Mi script principal quedaría de la siguiente manera.
from jinja2 import FileSystemLoader, Environment
from wsgiref.simple_server import make_server
def application(environ, start_response):
env = Environment(loader=FileSystemLoader("templates"))
template = env.get_template('template.html')
data = {
'title': 'WSGI tutorial',
'username': 'Codi'
}
html = template.render(data)
headers = [ ('Content-type', 'text/html; charset=utf-8') ]
start_response('200 OK', headers)
return [bytes(html, 'utf-8')]
server = make_server('localhost', 8000, application)
server.serve_forever()
Lo primero que hacemos es obtener nuestro template, nuestro archivo .html, posteriormente lo renderizamos utilizando un diccionario como argumento, en el diccionario colocamos todos los valores a utilizar en el template.
-
check_circle_outlineMódulo 1 | 17 clases
Introducción y Fundamentos
expand_more-
done_all
Clase 1
Introducción al curso de Python Web
-
done_all
Clase 2
Qué es Flask
-
done_all
Clase 3
WSGI python
-
done_all
Clase 4
Entorno de desarrollo e instalación de Flask
-
done_all
Clase 5
Crear servidor de Flask
-
done_all
Clase 6
Hola mundo (primera página web)
-
done_all
Clase 7
Renderizar template
-
done_all
Clase 8
Páginas web dinámicas
-
done_all
Clase 9
Ciclos y condicionales
-
done_all
Clase 10
Plantillas Jinja2
-
done_all
Clase 11
Parámetros
-
done_all
Clase 12
¿Qué es el query string?
-
done_all
Clase 13
Lectura de queries
-
done_all
Clase 14
Archivos estáticos
-
done_all
Clase 15
Herencia de plantillas
-
done_all
Clase 16
Links
-
done_all
Clase 17
Callbacks
-
-
check_circle_outlineMódulo 2 | 7 clases
Proyecto del curso
expand_more -
check_circle_outlineMódulo 3 | 7 clases
Formularios
expand_more -
check_circle_outlineMódulo 4 | 6 clases
Modelos
expand_more -
check_circle_outlineMódulo 5 | 4 clases
Validaciones
expand_more -
check_circle_outlineMódulo 6 | 7 clases
Autenticación de usuarios
expand_more -
check_circle_outlineMódulo 7 | 10 clases
CRUD - Crear, Leer, Actualizar y Eliminar
expand_more -
check_circle_outlineMódulo 8 | 3 clases
Servidor de correos
expand_more -
check_circle_outlineMódulo 9 | 5 clases
Extras
expand_more