创新互联Django4.0教程:Django4.0使用会话-当保存会话时

默认情况下,Django 只在会话被修改后才会向会话数据库保存会话——也就是说,是否已经分配或删除了它的任何字典值:

从网站建设到定制行业解决方案,为提供成都网站建设、成都网站制作服务体系,各种行业企业客户提供网站建设解决方案,助力业务快速发展。创新互联建站将不断加快创新步伐,提供优质的建站服务。

# Session is modified.
request.session['foo'] = 'bar'

# Session is modified.
del request.session['foo']

# Session is modified.
request.session['foo'] = {}

# Gotcha: Session is NOT modified, because this alters
# request.session['foo'] instead of request.session.
request.session['foo']['bar'] = 'baz'

在上面例子的最后一个例子中,我们可以通过在会话对象上设置 ​modified ​属性来明确地告诉会话对象它已经被修改:

request.session.modified = True

要想改变这个默认行为,可以设置 ​SESSION_SAVE_EVERY_REQUEST ​为 ​True ​。当设置为 ​True ​时,Django 会根据每个请求将会话保存到数据库中。
注意,仅在会话被创建或修改时发送会话 ​cookie ​。如果 ​SESSION_SAVE_EVERY_REQUEST ​为 ​True ​,则会话cookie将在每次请求时发送。
同样地,每次发送会话 cookie 时都会更新会话 cookie 的 ​expires ​部分。
如果响应状态代码为 500,会话不会被保存。

标题名称:创新互联Django4.0教程:Django4.0使用会话-当保存会话时
URL网址:http://www.shufengxianlan.com/qtweb/news22/83572.html

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

广告

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