django csrf验证失败请求被中断
Django CSRF验证失败。 请求中止.-未设置CSRF cookie (1)
我知道这个问题之前已经被问过了。 我已经尝试了几乎所有的人提供的选择,但我似乎无法解决它。 我是一个完整的新手,所以请让我知道我要去哪里错了。
我正在尝试写一个简单的原始形式。 到目前为止,我还没有实现任何身份验证或会话机制(但是从我读过的内容来看,这个问题并不重要,如果我错了,请纠正我)。
当我尝试提交表单时,出现以下错误:
Forbidden (403)
CSRF verification failed. Request aborted.
Reason given for failure:
CSRF cookie not set.
这是我的代码:
我的Views.py有这个方法:
def submit(request):
global alphabet_array
dishes = Dish.objects.all().order_by('name')
if request.method == "POST":
print request.POST['restaurant']
print request.POST['rating']
render_to_response('index.html', {}, context_instance=RequestContext(request))
else:
render_to_response('index.html', {}, context_instance=RequestContext(request))
许多人说,使用RequestContext解决了这个问题,但对我来说,这是行不通的。
模板如下所示:
<form role="form" action="/submit/" method="post">{% csrf_token %}
<div class="form-group">
<label for="">Restaurant Name</label>
<input type="text" name="restaurant" class="form-control" id="">
</div>
<div class="form-group">
<label for="">Rating</label>
<select class="form-control" name="rating">
<option>--</option>
<option>1 (very bad)</option>
<option>2 (bad)</option>
<option>3 (average)</option>
<option>4 (good)</option>
<option>5 (excellent)</option>
</select>
</div>
<button type="submit" class="btn btn-primary btn-block"><i class="fa fa-check-circle"></i> Save</button>
</form>
settings.py中的middleware_classes如下所示:
MIDDLEWARE_CLASSES = (
'django.middleware.common.CommonMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
)
django.middleware.csrf.CsrfViewMiddleware在那里,它是低于'django.contrib.sessions.middleware.SessionMiddleware'
我的url.py是有条目:
url(r'^admin/', include(admin.site.urls)),
url(r'^index/$', 'testapp.views.index'),
url(r'^starts_with/(?P<alphabet>.+)/dish/(?P<dish_id>\d+)/$', 'testapp.views.alphabet_dish'),
url(r'^starts_with/(?P<alphabet>.+)/$', 'testapp.views.alphabet'),
url(r'^submit/$', 'testapp.views.submit'),
我真的不确定这里有什么问题。 正如我所说,我已经阅读了类似的帖子,并尝试了答复中提到的一切。 我错过了什么? 我的浏览器是Chrome,它正在接受Cookie。
你的CSRF设置是好的。 问题是你没有返回结果 。 请记住,该视图是一个功能。 你需要return render_to_response(...)
不只是调用它(这也是为什么通过删除CSRF你didn't return an HttpResponse
错误)
除此之外,你正在做一些一般的东西是不正确的:
- 不要使用render_to_response (使用渲染)。
- 不要重复自己。
- 不要在Django中使用全局变量 。
因此:
def submit(request):
# global alphabet_array
dishes = Dish.objects.all().order_by('name')
if request.method == "POST":
print request.POST['restaurant']
print request.POST['rating']
return render(request, 'index.html', {})