Formulario de contacto vía CGI

Descarga: formulario-de-contacto.zip.

Si bien CGI es una tecnología obsoleta para los requisitos de la web en el siglo XXI, dado que la mayoría de los servicios de hosting compartido soportan el protocolo y, al correr sistemas basados en Linux, incluyen generalmente un intérprete de Python 2.6 o 2.7, es a menudo conveniente tener a mano un formulario de contacto para cualquier tipo de página web.

El siguiente código despliega en pantalla un formulario con cuatro campos: nombre, dirección de correo electrónico, mensaje y la verificación de seguridad vía reCAPTCHA. Una vez presionado el botón de envío, el script verifica la integridad de los cuatro campos mencionados junto con la prueba de seguridad de reCAPTCHA utilizando la librería requests y envía un correo electrónico a una dirección que escojas para que puedas leer los mensajes desde tu bandeja de entrada.

El diseño del formulario está a cargo del lector, como habrás observado, es bastante simple.

Los requerimientos para correr el código son los siguientes:

  • Python 2.5 a 2.7.
  • La librería requests.
  • Datos del servidor SMTP para enviar el correo electrónico.
  • Claves de reCAPTCHA para la verificación de seguridad.

contacto.py

#!/usr/bin/env python
# -*- coding: utf-8 -*-

from os import getenv
import cgi


# IP o dirección del servidor SMTP.
SMTP_SERVER = "smtp.[...].com"
# Puerto.
SMTP_PORT = 465
# Dirección desde donde se envía el correo.
EMAIL_ADDRESS = "[...]@[...].com"
# Constraseña.
PASSWORD = "********"
# Dirección a la que se envía el correo (usualmente igual a EMAIL_ADDRESS).
RECEIVER = "[...]@[...].com"

# Datos reCAPTCHA: clave del sitio y secreta.
PUBLIC_KEY = "[...]"
SECRET_KEY = "[...]"

# Código HTML del formulario.
FORM_HTML_CODE = \
"""
<form method="post">
  Nombre:<br /><input name="name" type="text" /><br />
  Email:<br /><input name="email" type="text" /><br />
  Mensaje:<br /><textarea name="message"></textarea><br />
  Verificación:<br />
  <div class="g-recaptcha" data-sitekey="{public_key}"></div>
  <br />
  <button type="submit">Enviar</button>
</form>
"""


def body():
    if getenv("REQUEST_METHOD") == "GET":
        # Mostrar formulario.
        print FORM_HTML_CODE.format(public_key=PUBLIC_KEY)
    else:
        # Enviar formulario.
        form_input = cgi.FieldStorage()
        required_fields = ("name", "email", "message",
                           "g-recaptcha-response")
        for field in required_fields:
            if field not in form_input:
                print("Debes completar todos los campos.")
                return
        
        # Verificar reCAPTCHA.
        import requests
        result = requests.post(
            "https://www.google.com/recaptcha/api/siteverify",
            data={
                "secret": SECRET_KEY,
                "response": form_input["g-recaptcha-response"].value,
                "remote-ip": getenv("REMOTE_ADDR")
            }
        )
        success = result.json()["success"]
        if not success:
            print "Realice nuevamente la verificación de seguridad."
            return
        
        from email.mime.multipart import MIMEMultipart
        from email.mime.text import MIMEText
        from smtplib import SMTP, SMTP_SSL
        
        mime_message = MIMEMultipart("alternative")
        mime_message["From"] = EMAIL_ADDRESS
        mime_message["To"] = RECEIVER
        mime_message["Subject"] = "Formulario de contacto"
        
        text = "Nombre: {}\nEmail: {}\n\n{}".format(
            form_input["name"].value,
            form_input["email"].value,
            form_input["message"].value
        )
        
        text = MIMEText(text, "plain", _charset="utf-8")
        mime_message.attach(text)
        
        # Iniciar sesión.
        smtp = SMTP(SMTP_SERVER, SMTP_PORT)
        # O bien la siguiente línea en lugar de la anterior
        # para conexiones seguras.
        # smtp = SMTP_SSL(SMTP_SERVER, SMTP_PORT)
        smtp.login(EMAIL_ADDRESS, PASSWORD)
        
        # Enviar correo.
        smtp.sendmail(EMAIL_ADDRESS, RECEIVER, mime_message.as_string())
        smtp.quit()
        
        print "¡Tu mensaje ha sido enviado!"


def main():
    # Headers.
    print "Content-Type: text/html"
    print
    
    print """\
    <html>
    <head>
      <title>Formulario de contacto</title>
      <meta http-equiv="content-type" content="text/html;charset=utf-8" />
      <script src='https://www.google.com/recaptcha/api.js'></script>
    </head>
    <body>
      <h3>Contacto</h3>"""
    
    body()
    
    print "</body></html>"


if __name__ == "__main__":
    main()

Para probar el script de forma local, puedes usar el servidor CGI provisto en el artículo Programación web vía CGI – Una introducción:

#!/usr/bin/env python
# -*- coding: utf-8 -*-

from BaseHTTPServer import HTTPServer
from CGIHTTPServer import CGIHTTPRequestHandler


class Handler(CGIHTTPRequestHandler):
    cgi_directories = ["/"]


httpd = HTTPServer(("", 8000), Handler)
httpd.serve_forever()

Y luego ingresar a http://localhost:8000/contacto.py habiendo completado las constantes al comienzo del archivo previamente (SMTP_SERVER, SMTP_PORT, etc.).

Para generar las claves de reCAPTCHA debes ingresar en este enlace con tu cuenta de Google. Para permitir que la verificación opere también en tu máquina local, debes generar un conjunto de claves para «localhost».

Curso online 👨‍💻

¡Ya lanzamos el curso oficial de Recursos Python en Udemy! Un curso moderno para aprender Python desde cero con programación orientada a objetos, SQL y tkinter en 2024.

Consultoría 💡

Ofrecemos servicios profesionales de desarrollo y capacitación en Python a personas y empresas. Consultanos por tu proyecto.

2 comentarios.

Deja una respuesta