大佬教程收集整理的这篇文章主要介绍了Django-在模板中使用了{%csrf_token%},但上下文未提供该值,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
你index.HTML
的呈现没有requestContext
。尝试这个:
def index(request):
return render_to_response('index.HTML', context_instance=requestContext(request))
我也建议你使用更方便的快捷方式render
:
from django.shortcuts import render
def index(request):
return render('index.HTML')
从文档:
render()与使用COntext_instance参数(强制使用requestContext)对render_to_response()的调用相同。
我是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 httpResponse
from 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,则可以得到我想要的,但这不是我想要的答案。
以上是大佬教程为你收集整理的Django-在模板中使用了{%csrf_token%},但上下文未提供该值全部内容,希望文章能够帮你解决Django-在模板中使用了{%csrf_token%},但上下文未提供该值所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。