Flask博客实战 – 实现登录注册功能

Flask博客实战 - 实现登录注册功能

上一节我们已经创建了一个用户应用,并创建了用户模型,那么我们这节就开始实现一个简单的用户登录注册功能

登录注册功能Flask有一个非常优秀的扩展Flask-login,我们可以选择使用这个扩展来实现,但为了学习我们暂时不使用这个第三方扩展,而是选择使用session来实现!

实现用户的登录功能

首先,我们需要完善登录的html页面, 路径为:app/auth/templates/login.html

{% extends ‘base.html’ %}{% block title %} 登录页 {% endblock title %}{% block hero %}{% endblock hero %}{% block main %} {% block auth_form %} {% endblock auth_form %} {% endblock main %}

代码详解:

这个登陆模板继承了base.html的样式,这个base.html中的模块及代码其实就是我们之前实现的首页,只是我们把他作为一个模板基类来继承他!

这段代码中其实就是写了一个输入账号密码表单,其他多余的代码都是为了实现表单的样式而存在的!

这里要特别说明的是这个input表单必须设置name属性,因为后端要根据此name属性来获取用户输入的值!其他属性则需要大家自行去了解学习!

登录功能的后端逻辑视图, 路径为:app/auth/views/auth.py

@bp.route(‘/login’, methods=[‘GET’, ‘POST’])def login(): # 登录视图 if request.method == ‘POST’: username = request.form[‘username’] password = request.form[‘password’] error = None user = auth.User.query.filter_by(username=username).first() if user is None: error = ‘该用户不存在!’ elif not check_password_hash(user.password, password): error = ‘密码不正确.’ if error is None: session.clear() session[‘user_id’] = user.id return redirect(url_for(‘index’)) flash(error) return render_template(‘login.html’)

代码详解: – request.method == ‘POST’判断当前请求是否为post请求方式 – error = None 来初始化一个错误变量,如果未通过登录验证,把错误信息通过消息传送到页面提示用户

user = auth.User.query.filter_by(username=username).first()if user is None: error = ‘该用户不存在!’elif not check_password_hash(user.password, password): error = ‘密码不正确.’

这段代码首先在数据库通过用户提交的用户名去查询该用户,用户不存在就会返回None返回错误提示,用户存在则判断密码是否正确,这里用到了一个check_password_hash()的方法,这是用来将密文密码解密后与用户输入密码比对方法,与之对应的有一个generate_password_hash()的方法用来加密明文密码保存到数据库!

if error is None: session.clear() session[‘user_id’] = user.id return redirect(url_for(‘index’))flash(error)

这段代码则是如果没有返回任何错误提示,说明该提交的表单符合我们的要求,并且数据库也存在该用户信息,那么我们只需要清空session,重新将session中的user_id设置为当前登录的id即可!

因此在实现登录注册逻辑之前就必须引入这两个方法:

from werkzeug.security import check_password_hash, generate_password_hash

登录功能虽然实现了,但我们数据库目前还没有任何一个用户,所以此时就应该要去实现用户的注册功能,向数据库新增用户,大概的逻辑是,用户输入用户名及两次密码,先判断该用户是否已经存在,存在则提示更换用户名,不存在则向数据库创建该用户信息,并清空session,重新设置user_id的值为注册用户的id,以达到注册成功后自动登录的目的!

实现用户的注册功能

首先,我们需要完善注册的html页面, 路径为:app/auth/templates/register.html

{% extends ‘login.html’ %}{% block title %}注册{% endblock title %}{% block auth_form %}{% endblock auth_form %}

这是注册页面的html,大家自行理解下,这里着重说一个我们在视图中通过flash()传递出来的消息,在模板中由以下代码接收!

{% with messages = get_flashed_messages() %} {% if messages %}

    {% for message in messages %}

  • {{ message }}
  • {% endfor %}

{% endif %} {% endwith %}

注册功能的后端逻辑视图, 路径为:app/auth/views/auth.py

@bp.route(‘/register’, methods=[‘GET’, ‘POST’])def register(): # 注册视图 if request.method == ‘POST’: username = request.form[‘username’] password = request.form[‘password’] password1 = request.form[‘password1’] if password != password1: flash(‘两次密码输入不一致!’) return redirect(url_for(‘auth.register’)) exists_user = auth.User.query.filter_by(username=username).first() if exists_user: flash(‘该用户名已经存在,请更换其他用户名!’) return redirect(url_for(‘auth.register’)) else: user = auth.User(username=username, password=generate_password_hash(password)) db.session.add(user) db.session.commit() session.clear() session[‘user_id’] = user.id return redirect(url_for(‘index’)) return render_template(‘register.html’)

这个注册的逻辑基本上涵盖了我们之前所有章节学到的知识点,这里就不再过多地去一一解释代码,大家可自行理解并完善注释!

实现用户退出登录功能

通过登录和注册功能的实现,我们已经清楚地知道,用户是否登录其实是判断session会话中是否存在用户的id来决定,那么推出登录,我们只需要清除session会话中的用户id即可,这里我们直接选择清空session的方式实现推出功能!

@bp.route(‘/logout’)def logout(): # 注销 session.clear() return redirect(url_for(‘index’))

在模板中获取用户信息

@bp.before_app_requestdef load_logged_in_user(): # 每个请求之前都回去session中查看user_id来获取用户 user_id = session.get(‘user_id’) if user_id is None: g.user = None else: g.user = auth.User.query.get(int(user_id))

bp.before_app_request()注册一个在视图函数之前运行的函数,无论请求什么 URL。 都会先检查用户 ID 是否存储在会话中,并从数据库获取该用户的数据,将其存储在 g.user 上,该数据在请求期间持续。

注册完这个函数之后,我们就可以在base.html中的导航的最右侧通过g.user的返回值,判断用户是否已经登录,显示不同的信息!

{% block navbar %} Home … 省略部分代码 {% if g.user %} 欢迎您 {{ g.user[‘username’] }} 个人中心 退出 {% else %} Sign up Log in {% endif %} {% endblock navbar %}

实现login_required装饰器

对于像下一章节我们要实现的用户中心以及管理后台,则必须是带有权限的访问,最基本的权限应该是必须是登录用户,那么所以说对于那些未登录的用户我们需要拒绝访问的功能!

这个其实思路也非常简单,既然在实现模板中调用用户信息的时候,我们把当前登录的用户信息添加到了g对象,那么我们只需要判断g.user的返回值是否为None即可判断用户是否登陆!

def login_required(view): # 限制必须登录才能访问的页面装饰器 @functools.wraps(view) def wrapped_view(**kwargs): if g.user is None: return redirect(url_for(‘auth.login’)) return view(**kwargs) return wrapped_view

到这里关于用户登录注册相关的基本权限问题我们就完成了,注意这些视图函数都在app/auth/views/auth.py文件中!

郑重声明:本文内容及图片均整理自互联网,不代表本站立场,版权归原作者所有,如有侵权请联系管理员(admin#wlmqw.com)删除。
(0)
用户投稿
上一篇 2022年6月21日
下一篇 2022年6月21日

相关推荐

  • 一加Ace Pro:首销1秒破亿,恭喜你了

    近段时间以来,各大手机厂商相继推出了骁龙8+手机,可以看得出这一次骁龙8+有多么给力,它优异的性能表现和功耗吸引了很多用户,但是搭载骁龙8+机型的手机太多了,比如小米12S系列、i…

    2022年8月16日
  • 安卓实用APP 6款堪称惊艳的安卓APP,个个实用至极,让手机无所不能

    大家的手机里有你认为非常惊艳的APP吗?今天小科给大家带来6款堪称惊艳的安卓APP,个个实用至极,让手机无所不能。 1.实用工具箱 这款多功能工具箱提供了从日常、查询、设备、特色、…

    2022年6月28日
  • 有了智能毛巾架,从此告别异味、细菌问题

    有这样一种产品大家见过吗?不但能烘干毛巾、衣物还可以智能消毒!相信大家都知道,毛巾用久了自然会变硬,而且湿毛巾放置时间久了就容易滋生细菌,并且还会散发异味。而智能毛巾架就能很好地解…

    2022年8月6日
  • 成功者崛起的三大本质逻辑,缺一不可大成

    刺激别人焦虑,来满足自己的欲望,基本成了成功学的核心秘密。成功学在诈骗的路上越走越远,但是真正的、关于成功的规律,却没有人研究,其实成功的核心要素是这三个关键词,无论什么人或是组织…

    2022年6月22日
  • 全球首款200元内的3000M路由器来了,实测表现出乎意料

    进入六月份后,能明显感觉到618大促活动的火热气息。借着这个重要的营销节点,不少厂商都会在这个时候推出应景的新品,通常会有不错的性价比优势。日前,京东云无线宝AX3000正式上架开…

    2022年6月19日
  • 2.6 DNS的客户端

    2.6 DNS的客户端 在Linux中,DNS是由BIND(Berkeley Internet Name Domain,伯克莱网间域名)软件实现的。BIND是一个c/s系统。 1.…

    2022年6月22日
  • 手机怎么做透明底的图片(透明图怎么做)

    我们平时处理图片素材的时候,经常会需要将图片的背景变成透明的留作素材,很多图片常常是白色的背景,制作图片也很不方便,今天就来给大家分享几个将图片背景变透明的方法! 方法一:使用电脑…

    2022年11月9日
  • 为何中国不怕苹果停用Apple Pay?《全球手机支付Top5》给你答案

    最近,苹果遇到了不小的麻烦。一方面,受到苹果对俄断供的影响,不少国内消费者也产生了恐慌,不再敢继续使用苹果设备,甚至不少果粉已经转而使用国产电子设备。另一方面,苹果终于妥协,在荷兰…

    2022年6月21日
  • MGFswap,全球首个基于多链和跨链的DEX即将震撼上线

    随着区块链逐步被世界认可以及新冠疫情带来的全球大水漫灌,数字资产呈现了爆发式的增长,至今在各大交易平台交易的数字货币已超过2000种。数字货币总市值已破8万亿美金,成交额过万亿美金…

    2022年6月24日
  • 快充,谁更快?

    原标题:快速充电技术火了 文 | 本报实习记者 杨梓 近日,多氟多发布公告称,其子公司广西宁福新能源科技与广州巨湾技研有限公司签订协议,共同投资设立广西宁福巨湾新能源科技有限公司,…

    2022年7月11日

联系我们

联系邮箱:admin#wlmqw.com
工作时间:周一至周五,10:30-18:30,节假日休息