创新互联Django4.0教程:Django4.0使用会话-在视图外使用会话

这部分的例子直接从 ​django.contrib.sessions.backends.db​ 后端导入 ​SessionStore​ 对象。在你自己的代码里,你应该考虑从 ​SESSION_ENGINE​ 指定的会话引擎导入 ​SessionStore ​。

>>> from importlib import import_module
>>> from django.conf import settings
>>> SessionStore = import_module(settings.SESSION_ENGINE).SessionStore

可以在视图外对会话数据进行操作的 API :

>>> from django.contrib.sessions.backends.db import SessionStore
>>> s = SessionStore()
>>> # stored as seconds since epoch since datetimes are not serializable in JSON.
>>> s['last_login'] = 1376587691
>>> s.create()
>>> s.session_key
'2b1189a188b44ad18c35e113ac6ceead'
>>> s = SessionStore(session_key='2b1189a188b44ad18c35e113ac6ceead')
>>> s['last_login']
1376587691

SessionStore.create()​ 用来创建一个新会话(即不从会话中加载,并带有 ​session_key=None​)。​save()​ 用来保存已存在的会话(即从会话存储中加载)。在新会话上调用 ​save()​ 也许会工作,但生成与现有会话相冲突的 ​session_key ​的概率很小。​create()​ 调用 ​save()​ 并循环,直到生成了未使用过的 ​session_key ​。
如果你正在使用 ​django.contrib.sessions.backends.db​ 后端,每个会话就会是一个普通的 Django 模型。 ​Session ​模型在 ​django/contrib/sessions/models.py​ 中定义。因为它就是一个普通模型,你可以使用普通的 Django 数据库 API 访问会话。

>>> from django.contrib.sessions.models import Session
>>> s = Session.objects.get(pk='2b1189a188b44ad18c35e113ac6ceead')
>>> s.expire_date
datetime.datetime(2005, 8, 20, 13, 35, 12)

注意你将需要调用 ​get_decoded()​ 来得到会话字典。这是必须的,因为字典是按照编码格式存储的:

>>> s.session_data
'KGRwMQpTJ19hdXRoX3VzZXJfaWQnCnAyCkkxCnMuMTExY2ZjODI2Yj...'
>>> s.get_decoded()
{'user_id': 42}

本文标题:创新互联Django4.0教程:Django4.0使用会话-在视图外使用会话
文章起源:http://www.shufengxianlan.com/qtweb/news33/445783.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联