Flask:会话

网站是提供给用户的,用户分为会员、普通用户、游客、管理员等。那么如何识别用户的身份呢?

会话

会话用途之一:登录验证

不妨先从代码开始...

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

 
17084259-889f812b934c3a56.png
图片.png

那如果输入的是

127.0.0.1:5000/log

 
17084259-6a190f2ffa1782c4.png
图片.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'] =

会话session的内容大致就是这些啦!

猜你喜欢

转载自blog.csdn.net/HizT_1999/article/details/101462013