项目使用插件:

flask_bootstrap

flask_wtf

flask_login

flask_sqlalchemy

用户模型类:

#!/usr/bin/env python

# -*- coding: utf-8 -*-

# @Time : 2017/8/1 14:45

# @File : Model.py

"""

数据模型

"""

from flask_login import LoginManager,login_user,UserMixin,logout_user,login_required

from Start import login_manger

from Start import db

class Users(UserMixin,db.Model):

__tablename__ = 'py_user'#对应mysql数据库表

id = db.Column(db.Integer, primary_key=True)

name = db.Column(db.String(64), unique=True, index=True)

pwd = db.Column(db.String(64), unique=True, index=True)

def __init__(self,name,pwd):

self.name=name

self.pwd=pwd

def get_id(self):

return unicode(self.id)

def __repr__(self):

return '' % self.name

def is_authenticated(self):

return True

def is_active(self):

return True

def is_anonymous(self):

return False

表单类:

#!/usr/bin/env python

# -*- coding: utf-8 -*-

# @Time : 2017/8/1 14:46

# @File : Form.py

"""

表单类

"""

from wtforms import StringField,SubmitField,PasswordField

from wtforms.validators import Required

from flask_wtf import FlaskForm

#登录表单

class Login_Form(FlaskForm):

name=StringField('name',validators=[Required()])

pwd=PasswordField('pwd',validators=[Required()])

submit=SubmitField('Login in')

#注册表单

class Register_Form(FlaskForm):

name=StringField('name',validators=[Required()])

pwd=PasswordField('pwd',validators=[Required()])

submit=SubmitField('register')

视图类:

#!/usr/bin/env python

# -*- coding: utf-8 -*-

# @Time : 2017/8/1 14:45

# @File : Views.py

"""

视图模型

"""

from flask import render_template,Blueprint,redirect,url_for,flash

from Start import login_manger

from Form import Login_Form,Register_Form

from Model import Users

from flask_login import LoginManager,login_user,UserMixin,logout_user,login_required

from DB import db

blog=Blueprint('blog',__name__) #蓝图

@blog.route('/')

def index():

form=Login_Form()

return render_template('login.html',form=form)

@blog.route('/index')

def l_index():

form = Login_Form()

return render_template('login.html',form=form)

@blog.route('/login',methods=['GET','POST'])

def login():

form=Login_Form()

if form.validate_on_submit():

user=Users.query.filter_by(name=form.name.data).first()

if user is not None and user.pwd==form.pwd.data:

login_user(user)

flash('登录成功')

return render_template('ok.html',name=form.name.data)

else:

flash('用户或密码错误')

return render_template('login.html',form=form)

#用户登出

@blog.route('/logout')

@login_required

def logout():

logout_user()

flash('你已退出登录')

return redirect(url_for('blog.index'))

@blog.route('/register',methods=['GET','POST'])

def register():

form=Register_Form()

if form.validate_on_submit():

user=Users(name=form.name.data,pwd=form.pwd.data)

db.session.add(user)

db.session.commit()

flash('注册成功')

return redirect(url_for('blog.index'))

return render_template('register.html',form=form)

项目启动类:

#!/usr/bin/env python

# -*- coding: utf-8 -*-

# @Time : 2017/8/1 14:50

# @File : Start.py

"""

应用启动类

"""

from flask import Flask,render_template,flash,url_for,redirect,Blueprint

from flask_bootstrap import Bootstrap

from flask_moment import Moment

from flask_wtf import FlaskForm

from flask_login import LoginManager,login_user,UserMixin,logout_user,login_required

from flask_sqlalchemy import SQLAlchemy

import sys

#解决flash的一个bug

defaultencoding = 'utf-8'

if sys.getdefaultencoding() != defaultencoding:

reload(sys)

sys.setdefaultencoding(defaultencoding)

app = Flask(__name__)

#各项插件的配置

app.config['SECRET_KEY']='kkk'

app.config['SQLALCHEMY_DATABASE_URI'] ='mysql://root:*****@localhost/mydata'#配置数据库

app.config['SQLALCHEMY_TRACK_MODIFICATIONS']=True

db = SQLAlchemy()

db.init_app(app)

bootstrap = Bootstrap(app)

moment=Moment(app)

login_manger=LoginManager()

login_manger.session_protection='strong'

login_manger.login_view='blog.login'

login_manger.init_app(app)

@login_manger.user_loader

def load_user(user_id):

from Model import Users

return Users.query.get(int(user_id))

"""

蓝图注册

"""

def init():

from Views import blog

app.register_blueprint(blueprint=blog,url_prefix='/blog')

if __name__ == '__main__':

init()

app.run(port=6626,debug=True)

本例使用了Jinja2模板进行渲染

基础类模板:

{% extends "bootstrap/base.html" %}

{% block title %}Flasky{% endblock %}

{% block head %}

{{ super() }}

{% endblock %}

{% block navbar %}

Toggle navigation

Flasky

  • Home

{% if current_user.is_authenticated %}

Log Out

{% else %}

Log In

{% endif %}

  • Register in

{% endblock %}

{% block content %}

{% for message in get_flashed_messages() %}

×

{{ message }}

{% endfor %}

{% block page_content %}{% endblock %}

{% endblock %}

{% block scripts %}

{{ super() }}

{{ moment.include_moment() }}

{% endblock %}

登录模板:

{% extends "form_base.html" %}

{% import "bootstrap/wtf.html" as wtf %}

{% block title %}Flasky{% endblock %}

{% block page_content %}

Login

{{ wtf.quick_form(form) }}

{% endblock %}

注册模板:

{% extends "form_base.html" %}

{% import "bootstrap/wtf.html" as wtf %}

{% block title %}Flasky{% endblock %}

{% block page_content %}

Register

{{ wtf.quick_form(form) }}

{% endblock %}

登录后模板:

{% extends 'form_base.html' %}

Title

{% block page_content %}

Hello,{{ name }}

{% endblock %}

启动后访问:

python注册登录+mysql_Flask+MySql实现用户登录注册相关推荐

  1. php mysql用户登录_php mysql实现用户登录功能的代码示例

    接着上次的php mysql添加用户的功能代码,今天来学习下php实现用户登录与注销的功能,通过跟踪session会话来保存用户的登陆状态. 1,登录页面 login.php 用户登录_www.# 用 ...

  2. 仿qq邮箱实现php+mysql动态用户登录

    仿qq邮箱实现php+mysql动态用户登录 1.大体思路 在前端输入用户名密码通过form表单提交到后台进性判断,如果数据库中该用户名和密码,则进行转跳,否者将该用户名密码插入数据库然后再进行转跳. ...

  3. python单用户登录_Django实现单用户登录的方法示例

    最近由于要毕业了写论文做毕设,然后还在实习发现已经好久都没有写博客了.今天由于工作需求,需要用Django实现单用户登录.大概意思就是跟QQ一样的效果,每个账号只能一个地方登录使用,限制账号的登录次数 ...

  4. php后台登录,简单的PHP数据后台实现用户登录,php后台用户登录

    简单的PHP数据后台实现用户登录,php后台用户登录 最近在写iOS一个小项目,用到了登录,所以用SAE搭了个简易的纯数据后台.PHP语句入门很简单,但是结合SQL就有点难度了.(代码都是SAE平台运 ...

  5. 单一用户登录,即当前用户登录后要踢出前一个登录,即做出踢人效果,如何实现?

    单一用户登录,即当前用户登录后要踢出前一个登录,即做出踢人效果,如何实现? 一般情况下,用户登录,有两种方式:cookie方式,session方式.一般情况下,session方式是使用最多的. 一.关 ...

  6. 麒麟系统登录界面开启root用户登录

    文章转自:https://blog.csdn.net/qq_33427869/article/details/123639654,全文转发,主要用于后续使用中可快速查阅. 编者目前使用的麒麟4.0.2 ...

  7. PHP+Mysql 实现用户登录,注册界面

    目标: 实现用户的登录 .注册 .修改密码.重置密码.添加书签,显示书签,删除书签 等功能 进一步目标: 实现对 用户输入信息的控制,具体表现在 对注册信息.登录信息的 的过滤,具有简单的防sql注入 ...

  8. PHP+MySQL实现用户登录注册API接口

    最近在学习PHP后台相关知识,利用PHP连接MySQL数据库实现了一个简单的用户登录注册及修改密码的API接口,接口为标准的json输出,本地验证通过.功能比较简单,不过也自己摸索了挺长时间,期间各种 ...

  9. php mysql 登录注销_PHP与MYSQL实现用户登录注销

    因为最近才学习php与mysql,为了写留言板的注册,登录与注销功能,接触到php的session会话机制,想要记录下来. Session: 代表服务器与浏览器的一次会话过程(其本来的含义是指有始有终 ...

最新文章

  1. Akka路由_RoundRobinRoutingLogic
  2. pix2pix tensorflow试验(GAN之图像转图像的操作)
  3. 关于Windows 7的64位系统不兼容某些控件的问题
  4. python 生成pdf收据_python如何与以太坊交互并将区块链信息写入SQLite
  5. [html] html5中的meta标签renderer有什么作用?
  6. 计算机知识点汇总职高,计算机辅导(知识点汇总) - 慈溪职高 网站首页.doc
  7. phpwind 报名插件 dpsign_修图神器!PS无损放大图片插件Alien Skin Blow Up,可调3600%...
  8. 算法复习——带修改莫队(bzoj2453)
  9. JavaScript字符串split方法
  10. 性能测试工具Loadrunner使用之一(Virtual User Generato)
  11. python 数据类笔试题_数据分析岗Python笔试题
  12. 计算机维修英语情景对话大全,实用英语短对话:修电脑
  13. 文库下载软件 冰点文库下载器 软件 百度网盘链接地址
  14. 微信小程序数据拼接_微信小程序字符串和变量如何拼接
  15. 一篇通俗易懂的文章初探NIO
  16. 查看本机IP地址、测试本机与其他设备是否连通、查本机IP归属地
  17. 内部系统界面设计【下】 | 设计技巧
  18. 计算机图像处理之形状变换
  19. 贪心入门+10道例题+解析代码
  20. Java 将表格数据导入word文档中

热门文章

  1. 火热的 Web 3,究竟离我们有多远?
  2. 寻优秀开源项目,百万程序员为你助力!
  3. 通过代码学 Sutton 强化学习:SARSA、Q-Learning 时序差分算法训练 CartPole
  4. 【正在直播】:CSDN直播间专属福利!1399买Airpods Pro
  5. 40万亿“新基建”来了!程序员的新翻身机会终于也来了!
  6. 我的 CDMA 往事
  7. 面试大厂被怼!这都搞不定,你只能做“搬运工”!
  8. 技术开发者应该如何构建小团队的微服务方案?
  9. 硬核干货! 你的业务是否适合上链、上链有那些坑?dfuse、慢雾、MYKEY大佬为你为你指点迷津……...
  10. 程序员除了会 CRUD 之外,还应该知道什么叫 CQRS!