Django-在模板中使用了{%csrf_token%},但上下文未提供该值
我是Django的新手,我仍在尝试掌握其功能。我使用Django 1.4.2创建了一个非常简单的项目,该项目的索引页面具有简单的形式,你可以在其中输入内容,结果页面在提交后显示输入内容(下面的代码)。
提交后,我收到错误403和以下消息:
在模板中使用了{%csrf_token%},但是上下文没有提供该值。这通常是由于未使用RequestContext引起的。warnings.warn(“模板中使用了{{csrf_token%},但是上下文没有提供该值。这通常是由于未使用RequestContext引起的。”)
index.html
<!DOCTYPE html><head>
<title>Index page</title>
</head>
<body>
<div id="header">Welcome to index page</div>
<div id="content">
<p>Enter your name</p>
<form action="/result/" method="post" accept-charset="utf-8">{% csrf_token %}
<input type="text" name="answer">
<input type="submit" value="Send!">
</form>
</div>
</body>
result.html
<!DOCTYPE html><head>
<title>Result page</title>
</head>
<body>
<div id="header">Here is the result</div>
<div id="content">
<p>Your name is: {{ answer }}</p>
</div>
</body>
views.py
from django.http import HttpResponsefrom django.shortcuts import render_to_response
from django.template import RequestContext
def index(request):
return render_to_response('index.html')
def result(request):
p = request.POST['answer']
return render_to_response('result.html', {'answer': p}, context_instance=RequestContext(request))
我已经研究了Internet上的文档和各种示例,但是我不明白自己在做什么错。如果我在settings.py中禁用django.middleware.csrf.CsrfViewMiddleware,则可以得到我想要的,但这不是我想要的答案。
回答:
你index.html
的呈现没有RequestContext
。尝试这个:
def index(request): return render_to_response('index.html', context_instance=RequestContext(request))
我也建议你使用更方便的快捷方式render
:
from django.shortcuts import renderdef index(request):
return render('index.html')
从文档:
render()与使用context_instance参数(强制使用RequestContext)对render_to_response()的调用相同。
以上是 Django-在模板中使用了{%csrf_token%},但上下文未提供该值 的全部内容, 来源链接: utcz.com/qa/420939.html