flask连接sqlalchemy数据库,实现简单的登录跳转功能
环境:python2.7
python库:flask,flask_wtf,wtforms,sqlalchemy
原理:运行app-连接数据库-打开登录页面-输入登录信息(错误->提示错误信息;正确跳转新的search页面)
贴上代码:
web.py
# -*- coding: utf-8 -*-
#
# web查询接口测试
# 需要登录->输入关键字->查询
from sqlalchemy import *
from sqlalchemy.orm import scoped_session, sessionmaker
###-----------连接数据库 type=mysql user:password localhost
db_connect_string = 'mysql://root:root@127.0.0.1:3306/flask?charset=utf8'
ssl_args = {'ssl':{'cert':'/home//ssl/client-cert.pem',
'key':'/home/shouse/ssl/client-key.pem',
'ca':'/home/shouse/ssl/ca-cert.pem'}
}
###创建引擎
engine = create_engine(db_connect_string, connect_args =ssl_args)
SessionType = scoped_session(sessionmaker(bind=engine, expire_on_commit=False)) ###构建连接数据库函数
def get_session():
return SessionType
####创建自动事务函数
from contextlib import contextmanager
@contextmanager
def session_scope():
db = get_session()
try:
yield db
db.commit()
except:
db.rollback()
raise
finally:
db.close() ####-------创建数据库字段
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import Column, Integer, String, ForeignKey, UniqueConstraint, Index
from sqlalchemy.orm import sessionmaker, relationship
from sqlalchemy import create_engine Base = declarative_base()
# 创建单表
#
###账户表account
class Account(Base):
__tablename__ = 'account'
id = Column(Integer, primary_key=True)
name = Column(String(32))
pwd = Column(String(16))
###用户表account
class Users(Base):
__tablename__ = 'users'
id = Column(Integer, primary_key=True)
name = Column(String(32))
__table_args__ = (
UniqueConstraint('id', 'name', name='uix_id_name'),
)
###地址account
class Address(Base):
__tablename__ = 'address'
id = Column(Integer, primary_key=True)
address = Column(String(32))
phone = Column(String(32))
user_id = Column(Integer, ForeignKey('users.id')) ###创建表
Base.metadata.create_all(engine) ##-----------------------------------分割线-------------------------------------## ######开始web脚本部分
import flask
from flask_wtf import FlaskForm
from wtforms import *
from wtforms.fields import (StringField, PasswordField,)
from wtforms.validators import DataRequired, Length
from flask import Flask, render_template, redirect,session
app = Flask(__name__)
import os
from os import path
d = path.dirname(__file__) ####定义SECRET_KEY保证安全性
app.config['SECRET_KEY'] = 'my web_test!!'
###定义登录表单字段
#user, password,submit
#再渲染到html页面 class LoginForm(FlaskForm):
# Text Field类型,文本输入框,必填,用户名长度为4到25之间
username = StringField('Username', validators=[DataRequired(u'.请输入用户名!!'),Length(min=4, max=25,message=u'请输入4-25个字符!')])
# Text Field类型,密码输入框,必填,必须同confirm字段一致
password = PasswordField('Password', validators=[
DataRequired(u'.请输入密码!!'),
Length(min=4, max=25,message=u'请输入4-25个字符!'),
])
submit = SubmitField('login') #####定义搜索页面字段
#key, submit
class SearchForm(FlaskForm):
key = StringField('Key',validators=[
DataRequired(),
Length(min=4, max=255)
])
submit = SubmitField('search') ###定义登录控制器 允许访问的方式 get/post
@app.route('/test/login', methods=['GET','POST'])
def LoginFormViews():
###示例登陆类
form = LoginForm()
if flask.request.method == "GET":
####get请求就显示表单页面,渲染字段->login.html
return render_template('login.html',form=form)
else:
#print form.image.data 验证通过
if form.validate_on_submit():
###开始check 用户名和密码
username = form.username.data
password = form.password.data
with session_scope() as db:
list = db.query(Account).filter(Account.name==username, Account.pwd==password).first()
if list:
print list
####把用户名记入session/cookies
session['username'] = username
return redirect('/test/search')
else:
return redirect('/test/login')
else:
#print form.errors
###把错误信息返回到页面
return render_template('login.html',form=form,error=form.errors) #######search控制器
@app.route('/test/search', methods=['GET','POST'])
def SearchFormViews():
form = SearchForm()
if flask.request.method == "GET":
####判断是否登录
if session.has_key('username'):
#return 'Logged in as %s' % session['username']
return render_template('search.html',form=form)
else:
return redirect('/test/login')
else:
#print form.image.data
if form.validate_on_submit():
key = form.key.data
####开始查询 字段
return redirect('/test/search')
else:
#print form.errors
###把错误信息返回到页面
return render_template('search.html',form=form,error=form.errors) ######注销控制器
@app.route('/test/logout', methods=['GET'])
def logout():
if flask.request.method == "GET":
####开始注销当前用户
session.pop('username',None)
return redirect('/test/login') if __name__ == '__main__':
app.run(host='127.0.0.1',port='', debug=False)
同一目录下新建templates文件夹存放静态文件

_formhelpers.html 配置文件,用来循环表单字段
{% macro render_field(field) %}
<div style="height:24px;">
<span>{{ field.label }}:</span>
{{ field(**kwargs)|safe }}
{% if field.errors %}
<b class=errors style="color:red">
{% for error in field.errors %}
<span>{{ error }}</span>'
{% endfor %}
</b>
{% endif %}
</div>
{% endmacro %}
login.html 登录文件
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>Form</title>
</head>
<body>
<div style="margin: 0 auto;width:200px; height: 40px; line-height: 40px;">登录系统</div> {% from "_formhelpers.html" import render_field %}
<form action='/test/login' method='post' name='LoginFormViews' enctype="multipart/form-data">
{{ form.hidden_tag() }}
{#{ form.csrf_token }#}
<table>
{{ render_field(form.username) }}
{{ render_field(form.password) }}
</table>
{{ form.submit }}
</form> <hr></hr> </body>
</html>
search.html
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>Form</title>
</head>
<body>
<div style="margin: 0 auto;width:200px; height: 40px; line-height: 40px;">搜索({{session['username']}})<b style="color:red;"><a href="/test/logout">注销</a></b></div> {% from "_formhelpers.html" import render_field %}
<form action='/test/news_form' method='post' name='NewsFormViews' enctype="multipart/form-data">
{{ form.hidden_tag() }}
{#{ form.csrf_token }#}
<table>
{{ render_field(form.key) }}
</table>
{{ form.submit }}
</form> <hr></hr> </body>
</html>
下次讲讲表单字段的使用,本次只是用了2种类型的字段,以及错误的提示信息。
flask连接sqlalchemy数据库,实现简单的登录跳转功能的更多相关文章
- jsp-3 简单的servlet连接mysql数据库 使用mvc的登录注册
简单的servlet连接mysql数据库 使用mvc的登录注册 commons-dbutils-1.6 mysql-connector-java-5.1.40-bin c3p0-0.9.5.2 mch ...
- 用asp连接Access数据库 制作简单登陆界面
[题外话:最近做Internet作业,在这写一个适合初学入门的ASP连接ACCESS数据库做登陆界面的简单的例子,以慰藉我一口气把以前做过的系统中的PHP代码全改成ASP代码来临时应付作业的心情... ...
- JavaWeb连接SQLServer数据库并完成一个登录界面及其功能设计。
一.JDBC连接SQLserver数据库的步骤: 1.下载SQLserver的JDBC驱动文件——Microsoft JDBC Driver 4.0 for SQL Server 2.例如下载得到的文 ...
- flask连接mysql数据库
from flask import Flask from flask_sqlalchemy import SQLAlchemy import pymysql pymysql.install_as_My ...
- Java连接MySQL数据库及简单的增删查改操作
主要摘自 https://www.cnblogs.com/town123/p/8336244.html https://www.runoob.com/java/java-mysql-connect.h ...
- Java连接MySQL数据库及简单操作代码
1.Java连接MySQL数据库 Java连接MySql需要下载JDBC驱动MySQL-connector-java-5.0.5.zip(举例,现有新版本).然后将其解压缩到任一目录.我是解压到D盘, ...
- 如何登录mysql? cmd怎么连接mysql数据库||从MYSQL客户端登录MYSQL
1 2 3 4 5 6 7 分步阅读 Mysql开源数据库,任何人都可以下载安装使用.那么安装好的mysql如何登陆连接mysql数据库呢?本经验咗嚛介绍几种常见的方法 工具/原料 mysql 连 ...
- python web开发-flask连接sqlite数据库
在之前的文章中我们介绍了如何在centOS中安装sqlite数据库. Sqlite安装完成后,本节就用flask来连接和操作sqlite数据库. 1. 数据准备 先在sqlite3中创建一 ...
- Go 连接 mysql 数据库的简单测试.
1. import 的时候 总是很慢 容易失败 所以 优先导入几个必须要的包 go get github.com/go-sql-driver/mysql 安装完之后 会在gopath 目录下发现相关的 ...
随机推荐
- Azure IoT Edge on Raspberry Pi 3 with Raspbian
在<Azure IoT Edge on Windows 10 IoT Core>一文中,我们以运行Windows 10 IoT Core的MinnowBoard MAX为例,详细讲述了Wi ...
- 51Nod 1267 4个数和为0 二分
给出N个整数,你来判断一下是否能够选出4个数,他们的和为0,可以则输出"Yes",否则输出"No".Input第1行,1个数N,N为数组的长度(4 <= ...
- php结合redis实现高并发下的抢购、秒杀功能 (转载)
抢购.秒杀是如今很常见的一个应用场景,主要需要解决的问题有两个: 1 高并发对数据库产生的压力 2 竞争状态下如何解决库存的正确减少("超卖"问题) 对于第一个问题,已经很容易想到 ...
- C++反汇编第四讲,反汇编中识别继承关系,父类,子类,成员对象
C++反汇编第四讲,反汇编中识别继承关系,父类,子类,成员对象 讲解目录: 1.各类在内存中的表现形式 备注: 主要复习开发知识,和反汇编没有关系,但是是理解反汇编的前提. 2.子类继承父 ...
- SQL Server学习之路(三):“增删改查”之“增”
0.目录 1.前言 2.通过SSMS添加数据 3.通过SQL语句添加数据 3.1 添加单条数据 3.2 添加多条数据 4.通过其他表导入数据 4.1 通过数据库中的其他表导入数据 4.2 通过exce ...
- Microsoft Flow 概览
作者:陈希章 发表于 2017年12月15日 前言 纵观一下我们周围的世界,以及我们每天忙忙碌碌的工作,你会"惊奇地"发现它们都是一个事件接着一个事件发生的.例如,我每天早上起来, ...
- Python2/3中的urllib库
urllib库对照速查表 Python2.X Python3.X urllib urllib.request, urllib.error, urllib.parse urllib2 urllib.re ...
- Qt快速上手(学习笔记四)
拖了大半年,今天终于有更新了...我自己都不好意思,最近太忙了! 今天讲一下:QML语法 一 概述 QML是一种专门用于构建用户界面的编程语言,它允许用户构建高性能,具有流畅特效的可视化应用程序,QM ...
- xxx金融后台管理系统详细版:包括本地开发调试详细步骤
效果演示地址, github地址: demo演示: 1.About 此项目是 vue2.0 + element-ui + node+mongodb 构建的后台管理系统,所有的数据都是从 ...
- day01_使用Android Studio创建第一个Android项目
使用Android Studio开发Android项目如此简单 watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize ...