参考自FLASK WEB开发一书,总结了一些对于登入的设计原理解析。
对于FLASK WEB开发一书的学习,在登入时出现数据库操作错误等问题,查阅大量资料后有结论是存在bug,因此写了一个只有登入功能的界面。
代码使用Python2.7环境,如果环境中无所需环境,请运行requirements.txt。 代码为:pip2 install -r requirements.txt 去安装虚拟环境相关文件。
因为只涉及登入功能,所以使用了sqlite数据库,数据库中只有一个登录账号,john,密码为:123 。登录界面登录成功后会显示登录成功,未登录成功则无显示。
-- coding:utf-8 --是强制修改编码模式,改为可识别中文。为了方便使用,使用了bootstrap的base.html界面制作以及bootstrap的wtforms表单方便设计。页面h5代码在源代码中。
为了方便编码和设计,未使用hash加密方式。
主函数代码如下:
# -*- coding:utf-8 -*-
from flask import Flask, render_template
from flask_sqlalchemy import SQLAlchemy
from flask_script import Manager
from flask_bootstrap import Bootstrap
from flask_wtf import Form
from wtforms import StringField, PasswordField, SubmitField
from wtforms.validators import DataRequired
from flask_migrate import Migrate, MigrateCommand
import os
# 设置数据库地址
basedir = os.path.abspath(os.path.dirname(__file__))
# 数据库配置
app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] =\
'sqlite:///' + os.path.join(basedir, 'data.sqlite')
app.config['SQLALCHEMY_COMMIT_ON_TEARDOWN'] = True
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
app.config['SECRET_KEY'] = 'hard to guess string'
# 系统初始化
db = SQLAlchemy(app)
manager = Manager(app)
bootstrap = Bootstrap(app)
migrate = Migrate(app, db)
manager.add_command('db', MigrateCommand)
# 数据库表单
class User(db.Model):
__tablename__ = 'users'
id = db.Column(db.Integer, primary_key=True)
username = db.Column(db.String(64), unique=True, index=True)
password = db.Column(db.String(128))
def __repr__(self):
return '<User %r>' % self.username
# 登录表单类
class LoginForm(Form):
username = StringField(u"用户名", validators=[DataRequired()])
password = PasswordField(u"密码", validators=[DataRequired()])
submit = SubmitField(u"登入")
# 路由修饰器设置,以及用户名检索和密码比对
@app.route('/', methods=['GET', 'POST'])
def login():
form = LoginForm()
if form.validate_on_submit():
user = User.query.filter_by(username=form.username.data).first()
password = form.password.data
if user is not None:
if password == user.password:
return render_template('login.html')
return render_template('index.html', form=form)
if __name__ == '__main__':
manager.run()