一个基于flask的web应用诞生 记录用户账户登录状态(6)


Posted in Python onApril 11, 2017

之前登录注册的功能都已经完成,但是登录成功回到首页发现还是白茫茫的一片,对的,title一直都写得博客,那么最终目的也是写出一个轻博客来,但是,在发表文章之前是不是要先记录一下登录状态呢?

用户登录

登录状态的记录方式有很多种,首先想到的应该就是使用flask自带的session,但flask还提供了一种更方便的扩展,即flask-login包,使用方式还和之前一样,首先需要安装:

pip3.6 install flask-login

然后在default.py中进行初始化:

from flask.ext.login import LoginManager

......

login_manager=LoginManager()
login_manager.session_protection="strong" 

#可设置为None,basic,strong已提供不同的安全等级
login_manager.login_view="login" #设置登录页

然后按照需求对User模型进行修改,因为Flask-Login要求User模型必须实现四个方法,分别为:

is_authenticated() 判断是否登录,登录返回True,否则返回False
is_active() 是否允许登录,即用户是否已被禁用,如禁用返回False
is_anonymous() False为普通用户
get_id() 返回用户唯一标识符,使用Unicode编码

这四个方法在User模型中直接实现即可,但是还有一种更简单的方式,即继承Flask-Login提供的UserMixin类,它里边包含了这些方法的默认实现,修改后的User模型为:

from flask.ext.login import UserMixin

class User(UserMixin,db.Model):
  __tablename__="users"
  id=db.Column(db.Integer,primary_key=True)
  ......

flask-login还要求程序实现一个回调函数,已使用指定的标识符家在用户:

@login_manager.user_loader
def load_user(user_id):
  return User.query.get(int(user_id))

之后,就可以方便的使用flask-login框架,继续修改首页模板的导航部分,以便显示用户名及相应信息:

{%extends "bootstrap/base.html "%}
{% block title%}牛博客 {% endblock %}<!--覆盖title标签-->

{% block navbar %}
<nav class="navbar navbar-inverse"><!-- 导航部分 -->
 <div class="navbar-header">
   <a class="navbar-brand" href="#" rel="external nofollow" rel="external nofollow" >
    牛博客
   </a>
 </div>

 <div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1">
   <ul class="nav navbar-nav">
    <li><a href="/" rel="external nofollow" >首页</a></li>
   </ul>
   <ul class="nav navbar-nav navbar-right">
    {% if current_user.is_authenticated %}
      <li><p class="navbar-text"><a href="#" rel="external nofollow" rel="external nofollow" class="navbar-link">{{current_user.username}}</a> 您好</p></li>
      <li><a href="{{url_for('logout')}}" rel="external nofollow" >登出</a></li>
    {% else %}
      <li><a href="{{url_for('login')}}" rel="external nofollow" >登录</a></li>
    {% endif %}
   </ul>
  </div><!-- /.navbar-collapse -->
</nav>
{% endblock %}
{% block content %} <!--具体内容-->
<div class="container">
</div>
{% endblock %}

这里新出现url_for方法,它的主要功能是使用程序中的信息生成URL,比如传入视图的方法名,生成对应的url,还可以通过方法的动态参数生成url的参数,如url_for('index',age=5)结果为/?age=5

主要内容为判断是否登录,若登录显示 {{用户名}}你好,并提供登出功能,否则显示登录链接。

修改登录表单:

class LoginForm(Form):
  username=StringField("请输入用户名",validators=[DataRequired()])
  password=PasswordField("请输入密码")
  remember_me=BooleanField("记住我")
  submit=SubmitField("登录")

增加记住我项目, BooleanField默认为多选按钮

修改登录视图方法:

@app.route("/login",methods=["GET","POST"])
def login():
  form=LoginForm()
  if form.validate_on_submit():
    username = form.username.data
    password = form.password.data
    user = User.query.filter_by(username=username, password=password).first()
    if user is not None:
      login_user(user,form.remember_me.data)
      return redirect(url_for("index"))
    else:
      flash("您输入的用户名或密码错误")
      return render_template("/login.html",form=form) # 返回的仍为登录页
  return render_template("/login.html",form=form)

其中login_user为flask_login插件提供,用于设置用户登录,其中第二个参数即为记住我选项,若输入True,则提供cookie存储状态,否则关闭浏览器状态即取消

新增登出方法:

@app.route("/logout",methods=["GET","POST"])
@login_required
def logout():
  logout_user()
  return redirect(url_for("index"))

此方法很简单,直接使用flask-login提供的登出方法即可,注意@login_required装饰器表示,只有登录用户才可访问此视图方法。

运行测试一下,输入首页地址:

一个基于flask的web应用诞生 记录用户账户登录状态(6)

点击右上角的登录键:

一个基于flask的web应用诞生 记录用户账户登录状态(6)

输入用户名zhangji 密码123 并选择记住我,点击确定:

一个基于flask的web应用诞生 记录用户账户登录状态(6)

注意红线部分,显示正常,此时点击登出:

一个基于flask的web应用诞生 记录用户账户登录状态(6)

注意红线部分,回到初始状态。

章节结语

接下来本来应该是发帖及关注功能,但很明显,现在代码都在default.py中,对于代码结构越来越力不从心,所以本章的篇幅比较小,下一章将重点对已有代码进行重构,并对功能进行分组,然后在继续写接下来的功能。谢谢观看。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
基于Python数据可视化利器Matplotlib,绘图入门篇,Pyplot详解
Oct 13 Python
Python 删除连续出现的指定字符的实例
Jun 29 Python
python数据批量写入ScrolledText的优化方法
Oct 11 Python
在PyCharm下使用 ipython 交互式编程的方法
Jan 17 Python
django框架CSRF防护原理与用法分析
Jul 22 Python
使用OpCode绕过Python沙箱的方法详解
Sep 03 Python
python多线程案例之多任务copy文件完整实例
Oct 29 Python
Flask之pipenv虚拟环境的实现
Nov 26 Python
利用pytorch实现对CIFAR-10数据集的分类
Jan 14 Python
使用PyWeChatSpy自动回复微信拍一拍功能的实现代码
Jul 02 Python
python 实现弹球游戏的示例代码
Nov 17 Python
Python爬虫基础初探selenium
May 31 Python
一个基于flask的web应用诞生 用户注册功能开发(5)
Apr 11 #Python
一个基于flask的web应用诞生 flask和mysql相连(4)
Apr 11 #Python
一个基于flask的web应用诞生 bootstrap框架美化(3)
Apr 11 #Python
一个基于flask的web应用诞生 使用模板引擎和表单插件(2)
Apr 11 #Python
非递归的输出1-N的全排列实例(推荐)
Apr 11 #Python
一个基于flask的web应用诞生(1)
Apr 11 #Python
Python 文件处理注意事项总结
Apr 10 #Python
You might like
PHPMyadmin 配置文件详解(配置)
2009/12/03 PHP
php的list()的一步操作给一组变量进行赋值的使用
2011/05/18 PHP
php数组冒泡排序算法实例
2016/05/06 PHP
PHP网站自动化配置的实现方法(必看)
2017/05/27 PHP
php面向对象的用户登录身份验证
2017/06/08 PHP
PHP实现链式操作的三种方法详解
2017/11/16 PHP
PHP基于redis计数器类定义与用法示例
2018/02/08 PHP
laravel框架select2多选插件初始化默认选中项操作示例
2020/02/18 PHP
javascript语句中的CDATA标签的意义
2007/05/09 Javascript
javascript原始值和对象引用实例分析
2015/04/25 Javascript
如何根据百度地图计算出两地之间的驾驶距离(两种语言js和C#)
2015/10/29 Javascript
Augularjs-起步详解
2016/07/08 Javascript
canvas学习之API整理笔记(二)
2016/12/29 Javascript
js中的面向对象入门
2017/03/06 Javascript
jquery 禁止鼠标右键并监听右键事件
2017/04/27 jQuery
JavaScript无操作后屏保功能的实现方法
2017/07/04 Javascript
通过命令行创建vue项目的方法
2017/07/20 Javascript
Angular项目从新建、打包到nginx部署全过程记录
2017/12/09 Javascript
解决vue-router中的query动态传参问题
2018/03/20 Javascript
Vue单页应用引用单独的样式文件的两种方式
2018/03/30 Javascript
vue中axios的二次封装实例讲解
2019/10/14 Javascript
[01:09:13]DOTA2-DPC中国联赛 正赛 CDEC vs XG BO3 第三场 1月19日
2021/03/11 DOTA
python getopt 参数处理小示例
2009/06/09 Python
python中将字典转换成其json字符串
2014/07/16 Python
零基础写python爬虫之爬虫的定义及URL构成
2014/11/04 Python
Python魔术方法详解
2015/02/14 Python
浅谈Python NLP入门教程
2017/12/25 Python
python yield和Generator函数用法详解
2020/02/10 Python
美国在线面料商店:Fashion Fabrics Club
2020/01/31 全球购物
Loreto Gallo英国:欧洲领先的在线药房
2021/01/21 全球购物
医学生实习自我鉴定
2013/09/27 职场文书
机电专业大学生职业规划书范文
2014/02/25 职场文书
学习优秀党务工作者先进事迹材料思想报告
2014/09/17 职场文书
村干部群众路线整改措施思想汇报
2014/10/12 职场文书
2014教师评职称工作总结
2014/11/10 职场文书
2014年人民调解工作总结
2014/12/08 职场文书