环境: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数据库,实现简单的登录跳转功能的更多相关文章

  1. 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 ...

  2. 用asp连接Access数据库 制作简单登陆界面

    [题外话:最近做Internet作业,在这写一个适合初学入门的ASP连接ACCESS数据库做登陆界面的简单的例子,以慰藉我一口气把以前做过的系统中的PHP代码全改成ASP代码来临时应付作业的心情... ...

  3. JavaWeb连接SQLServer数据库并完成一个登录界面及其功能设计。

    一.JDBC连接SQLserver数据库的步骤: 1.下载SQLserver的JDBC驱动文件——Microsoft JDBC Driver 4.0 for SQL Server 2.例如下载得到的文 ...

  4. flask连接mysql数据库

    from flask import Flask from flask_sqlalchemy import SQLAlchemy import pymysql pymysql.install_as_My ...

  5. Java连接MySQL数据库及简单的增删查改操作

    主要摘自 https://www.cnblogs.com/town123/p/8336244.html https://www.runoob.com/java/java-mysql-connect.h ...

  6. Java连接MySQL数据库及简单操作代码

    1.Java连接MySQL数据库 Java连接MySql需要下载JDBC驱动MySQL-connector-java-5.0.5.zip(举例,现有新版本).然后将其解压缩到任一目录.我是解压到D盘, ...

  7. 如何登录mysql? cmd怎么连接mysql数据库||从MYSQL客户端登录MYSQL

    1 2 3 4 5 6 7 分步阅读 Mysql开源数据库,任何人都可以下载安装使用.那么安装好的mysql如何登陆连接mysql数据库呢?本经验咗嚛介绍几种常见的方法 工具/原料   mysql 连 ...

  8. python web开发-flask连接sqlite数据库

    在之前的文章中我们介绍了如何在centOS中安装sqlite数据库. Sqlite安装完成后,本节就用flask来连接和操作sqlite数据库. 1.       数据准备 先在sqlite3中创建一 ...

  9. Go 连接 mysql 数据库的简单测试.

    1. import 的时候 总是很慢 容易失败 所以 优先导入几个必须要的包 go get github.com/go-sql-driver/mysql 安装完之后 会在gopath 目录下发现相关的 ...

随机推荐

  1. 洛谷 P3379 【模板】最近公共祖先(LCA)Tarjan离线

    题目链接:LCA tarjan离线 这道题目WA无数发,最后还是参考了大神的blog 谁会想到因为一个输入外挂WA呢 大概是我的挂是假挂吧...orz(其实加上外挂,速度提升很多) 用链式前向星保存边 ...

  2. 如何扩展或者添加硬盘给VMware的Linux操作系统

    我们在使用Linux系统一段时间以后,可能添加的东西原来越多导致原来开辟的硬盘不够,当硬盘剩余空间过小时Ubuntu系统也会给出提示或者可以通过df  -hl命令查看你硬盘使用情况如下图所示:我已经用 ...

  3. 大数据学习系列之二 ----- HBase环境搭建(单机)

    引言 在上一篇中搭建了Hadoop的单机环境,这一篇则搭建HBase的单机环境 环境准备 1,服务器选择 阿里云服务器:入门型(按量付费) 操作系统:linux CentOS 6.8 Cpu:1核 内 ...

  4. iOS 提交AppStore不出现构建的版本

    提交App Store不出现构建的版本 Xcode版本:8.0 近日往App Store上跟新一个版本,提交了好几次,built号增加了好几个,上传每次都成功了,但是在iTunes Contact上一 ...

  5. Android HandlerThread 源码分析

    HandlerThread 简介: 我们知道Thread线程是一次性消费品,当Thread线程执行完一个耗时的任务之后,线程就会被自动销毁了.如果此时我又有一 个耗时任务需要执行,我们不得不重新创建线 ...

  6. GDAL编译

    使用cmd命令行编译 1.首先在“开始菜单\所有程序\Microsoft Visual Studio 2008\Visual Studio Tools\ Visual Studio 2008命令提示” ...

  7. java 之 职责链模式(大话设计模式)

    目前很多OA办公自动化软件,加快了办公效率,简化流程.相信很多小伙伴都用过.笔者了解到的大多数办公软件底层实现流程大多数采用的都是Activity或者是JBPM框架. 今天笔者要说的也是类似于流程的一 ...

  8. 》》豆瓣API

    <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...

  9. springMVC(1)---@RequestMapping详解

    @RequestMapping详解 RequestMapping是一个用来处理请求地址映射的注解,可用于类或方法上.用于类上,表示类中的所有响应请求的方法都是以该地址作为父路径.这句话,太熟悉了.   ...

  10. mssql查询过去一段时间数据库中执行过的语句及执行效率

    SELECT TOP 1000 ST.text AS '执行的SQL语句', QS.execution_count AS '执行次数', QS.total_elapsed_time AS '耗时', ...