网站是提供给用户的,用户分为会员、普通用户、游客、管理员等。那么如何识别用户的身份呢?
会话
会话用途之一:登录验证
不妨先从代码开始...
log_in.py
@app.route('/common_user_login')
def common_log_in():
if session.get('common'):
return '您已登录成功'
else:
return '请先登录'
这段代码将'/common_user_login'这个URL与common_log_in这个方案绑定,在方案中做出判定,并返回不同的结果。在这里我们发现了if语句中的条件为
session.get['common']
一头雾水是吗,我们再来看下面的代码:
log.py
@app.route('/log')
def log():
session['common'] = 'True'
return redirect('/common_user_login')
多说无益,我们先跑一跑试试效果
首先我们直接在URL中输入
127.0.0.1:5000/common_user_login
图片.png
那如果输入的是
127.0.0.1:5000/log
图片.png
为什么?
仔细观察的朋友可能会发现,网址明明就是一样的
log.py
@app.route('/log')
def log():
session['common'] = 'True'
return redirect('/common_user_login')
我们来回顾以下log.py。将'/log'这个URL绑定为一个叫做log的方案,在这个方案中,经过了一句session['common'],最终重定向到了'/common_user_login'的URL中。
重定向相关的内容将在之后说明
那么经过的这句话,就是对session(会话)的一个定义。session可以理解为一个字典,session['common'] = 'True' 的含义为,将common这个索引的值赋值为'True'这个字符串。当然你也可以赋值为其他的,比如:
session['common'] = 'I am good'
True只是一个字符串哦
在经过初始化之后,
log_in.py
def common_log_in():
if session.get('common'):
return '您已登录成功'
else:
return '请先登录'
当中的if session.get('common')语句返回值为1,含义为在session当中,对于索引名为'common'找到对应项了,于是,程序返回了'您已登录成功'
我们来看一下整个程序的代码
from flask import Flask, session, redirect
app = Flask(__name__)
app.config['SECRET_KEY']='hereismykeytosession'
@app.route('/common_user_login')
def common_log_in():
if session.get('common'):
return '您已登录成功'
else:
return '请先登录'
@app.route('/log')
def log():
session['common'] = 'True'
return redirect('/common_user_login')
if __name__ == '__main__':
app.run(debug = True)
要注意的是,flask中的会话session需要配置"密码",也就是
app.config['SECRET_KEY']='hereismykeytosession'
这一语句。
session默认过期时间为你关闭浏览器或清楚缓存时,当然你也可以设置过期时间
app.config['PERMANENT_SESSION_LIFETIME'] =