环境: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. Scala中的override

    Scala中的override override是覆盖的意思,在很多语言中都有,在scala中,override是非常常见的,在类继承方面,它和java不一样,不是可写可不写的了,而是必须写的.如果不 ...

  2. 【转】Python微信好友头像拼接图

    转自:Python微信好友头像拼接图 今天在朋友圈看到有人发了微信好友拼接图,心里满是新奇,看了下评论才知道用Python写的.心里痒痒,立马就安装了下Python. 安装好了之后,看了下大神的代码, ...

  3. 删除kafka的topic及kafka基本命令

    kafka的topic默认是不允许被删除的,删除后在topic后会出现”marked for deletion”字样,实际并未删除,现在创建同样的topic会提示topic已经存在. 解决办法: se ...

  4. 利用纯CSS美化checkbox和radio和滑动按钮的实现

    W3C提供的CheckBox和radio的原始样式非常的丑,而且在不同的额浏览器表现还不一样,使用常规的方法添加样式没法进行修改样式 一, 单选按钮 <html> <head> ...

  5. gulp杂记

    一.什么是gulp gulp是前端开发过程中对代码进行构建的工具,是自动化项目的构建利器:她不仅能对网站资源进行优化,而且在开发过程中很多重复的任务能够使用正确的工具自动完成:使用她,我们不仅可以很愉 ...

  6. vue项目的骨架及常用组件介绍

    vue项目基础结构 一个vue的项目,我觉得最小的子集其实就是{vue,vue-router,component},vue作为基础库,为我们提供双向绑定等功能.vue-router连接不同的" ...

  7. 解析XML文件之使用SAM解析器

    XML是一种常见的传输数据方式,所以在开发中,我们会遇到对XML文件进行解析的时候,本篇主要介绍使用SAM解析器,对XML文件进行解析. SAX解析器的长处是显而易见的.那就是SAX并不须要将全部的文 ...

  8. 【NOI2010】海拔【平面图最小割】

    [问题描写叙述] YT市是一个规划良好的城市,城市被东西向和南北向的主干道划分为n×n个区域.简单起见.能够将YT市看作 一个正方形,每个区域也可看作一个正方形.从而.YT城市中包含(n+1)×(n+ ...

  9. JAVA入门[10]-mybatis分页查询

    1.添加分页插件 在mybatis-generator-config.xml添加plugin节点: <plugin type="org.mybatis.generator.plugin ...

  10. jquery实现ajax提交表单

    一般情况下,我们提交form表单采用的是submit的方法,典型的场景如下. <form id="thisForm" method="post" acti ...