默认情况下,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,会话不会被保存。
Model._default_manager若你使用自定义 Manager 对象,注意 Django 遇到的第一个 Manager (按照你在模型中定义的顺序)...
使用内部 Meta类 来给模型赋予元数据,就像:from django.db import modelsclass Ox(models.Model):horn_length = model...
编写一个简单的表单让我们更新一下在上一个教程中编写的投票详细页面的模板 ("polls/detail.html") ,让它包含一个 HTML form...
默认测试客户端SimpleTestCase.clientdjango.test.*TestCase 实例中的每个测试用例都可以访问一个 Django 测试客户端的实例...
Java Swing教程 -Java Swing JRadioButtonJRadioButton有两种状态:选中和未选中。当我们需要用户进行单选时使用一组JRadioButton...