Diferencia entre revisiones de «Usuario:Lmorillas/desarrollo web servidor/flask/ejemplo completo»
De WikiEducator
(→Configuración base de datos) |
(→Modelo de usuario) |
||
Línea 155: | Línea 155: | ||
== Modelo de usuario == | == Modelo de usuario == | ||
+ | '''models.py''' | ||
+ | <source lang="python"> | ||
+ | db = SQLAlchemy() | ||
+ | |||
+ | |||
+ | class User(db.Model): | ||
+ | __tablename__ = 'usuarios' | ||
+ | uid = db.Column(db.Integer, primary_key = True) | ||
+ | nombre = db.Column(db.String(100)) | ||
+ | apellido = db.Column(db.String(100)) | ||
+ | email = db.Column(db.String(120), unique=True) | ||
+ | pwdhash = db.Column(db.String(54)) | ||
+ | |||
+ | def __init__(self, nombre, apellido, email, password): | ||
+ | self.nombre = nombre.title() | ||
+ | self.apellido = apellido.title() | ||
+ | self.email = email.lower() | ||
+ | self.set_password(password) | ||
+ | |||
+ | def set_password(self, password): | ||
+ | self.pwdhash = generate_password_hash(password) | ||
+ | |||
+ | def check_password(self, password): | ||
+ | return check_password_hash(self.pwdhash, password) | ||
+ | </source> | ||
== Página de perfil == | == Página de perfil == |
Revisión de 10:27 9 nov 2013
Previo
Seguiremos los siguientes tutoriales:
Repositorio de código de clase:
|
Estructura inicial
* Crear proyecto en eclipse
Tip: Estructura inicial
|
Páginas estáticas. Home y about
layout.html home.html about.html
Tip: Páginas estáticas
|
Formulario de contacto
Tip: Páginas estáticas
|
Estilo en formulario de contacto
|
Validación de formularios
|
Mensajes de error
Tip: Mensajes de error
|
Mensajes específicos de error
{% for mensaje in form.nombre.errors %} <div class="flash">{{ mensaje }}</div> {% endfor %} {% for mensaje in form.email.errors %} <div class="flash">{{ mensaje }}</div> {% endfor %} {% for mensaje in form.asunto.errors %} <div class="flash">{{ mensaje }}</div> {% endfor %} {% for mensaje in form.mensaje.errors %} <div class="flash">{{ mensaje }}</div> {% endfor %} |
Enviando correo
- Estensión: flask-mail
pip install flask-mail
from flask.ext.mail import Message, Mail # configuración MAIL_SERVER = "smtp.gmail.com" MAIL_PORT = 465 MAIL_USE_SSL = True MAIL_USERNAME = 'dwesdaw@gmail.com' # en mi ejemplo MAIL_PASSWORD = 'tu password' def contacto(): form = ContactForm() ... else: msg = Message(form.asunto.data, sender='dwesdaw@gmail.com', recipients=['destinatario']) msg.body = """ From: %s <%s> %s """ % (form.nombre.data, form.email.data, form.mensaje.data) mail.send(msg) return render_template('contacto.html', exito=True, nombre = form.nombre.data ) ...
Menú contactos
layout.html
Configuración base de datos
- Instalar mysql y python-mysql
SQLALCHEMY_DATABASE_URI = 'mysql://userflask:******@localhost/appFlask' from models import db db.init_app(app)
Modelo de usuario
models.py
db = SQLAlchemy() class User(db.Model): __tablename__ = 'usuarios' uid = db.Column(db.Integer, primary_key = True) nombre = db.Column(db.String(100)) apellido = db.Column(db.String(100)) email = db.Column(db.String(120), unique=True) pwdhash = db.Column(db.String(54)) def __init__(self, nombre, apellido, email, password): self.nombre = nombre.title() self.apellido = apellido.title() self.email = email.lower() self.set_password(password) def set_password(self, password): self.pwdhash = generate_password_hash(password) def check_password(self, password): return check_password_hash(self.pwdhash, password)
Página de perfil
Entrar y salir
Despliegue en Apache
Despliegue en Heroku
Configuración
conf.py
SECRET_KEY = '\x84\xed\xca\xe36\x8d\x17\xd4\xb3X\xfd1\xdfJx\xc6\xe9\xcf\x00\xdf\x9e \xa9l' MAIL_SERVER = "smtp.gmail.com" MAIL_PORT = 465 MAIL_USE_SSL = True MAIL_USERNAME = 'dwesdaw@gmail.com' # en mi ejemplo MAIL_PASSWORD = 'tu password' SQLALCHEMY_DATABASE_URI = 'mysql://userflask:*******@localhost/appFlask'
app.py
from conf import * ... app = Flask(__name__) app.config.from_object(__name__) ...
Documentación adicional