很少会在HTML
响应中呈现Django消息。然后,用户GET
是另一个页面,再次呈现Django消息。有时,用户此后将GET
另一页,并且将再次显示相同的消息。
这很少发生,但是当它发生时,大多数用户会在一段时间内看到相同的行为。 (它发生在一组跨浏览器测试中,并且房间里的每个人在他们的每台计算机上看到相同的行为大约五分钟,然后离开。)
许多不同的观点都出现了这种情况;此外,每个视图都以相同的方式添加它们(见下文)。
我无法在部署的环境(运行wsgi.py
)或在本地环境(运行manage.py
)上运行项目时可靠地重现错误。 (我会注意到我从未在本地看到过这个问题。)
有谁知道为什么会这样?
正在添加成功消息的示例。
messages.success(
request,
"Changes to {form} {request} were successfully saved."\
.format(form=self.form.display_name,
request=serv_request_id_as_url(self.serv_request))
)
这是呈现消息的模板代码:
<div id="messages">
{% for message in messages %}
<div class="alert alert-{{ message.tags }}">
<a class="close" data-dismiss="alert" href="#" title="Close"><span class="accessibility">Close this message.</span>×</a>
<strong>{{ message.message|safe }}</strong>
</div>
{% endfor %}
</div>
相关设置:
MIDDLEWARE_CLASSES = (
'django.middleware.gzip.GZipMiddleware',
'django.middleware.common.CommonMiddleware',
'outage.middleware.OutageMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.transaction.TransactionMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
'utdirect.middleware.HttpHeaderMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware', ... )
MESSAGE_STORAGE = 'django.contrib.messages.storage.session.SessionStorage'
DATABASES = {'default': {'ENGINE': 'django.db.backends.oracle',
...}}
答案 0 :(得分:2)
这似乎是由Django中的缓存引起的一个着名问题。以下是一位Django核心开发人员的评论:
“我不认为Django可以自动正确地处理这个问题。 循环遍历网站基本模板中的消息是一种非常常见的模式。如果我们仅仅因为消息可能在给定页面上显示而禁用缓存,那么我们就是为大多数网站删除缓存。“