CSRF令牌丢失或不正确,即使我有{%csrf_token%}

use*_*222 9 html python django

我在views.py文件中引用此方法时遇到此错误:

def AddNewUser(request):
    a=AMI()
    if(request.method == "POST"):
        print(request.POST)
       # print(request['newUser'])
       # print(request['password'])
    return render_to_response("ac/AddNewUser.html", {})
Run Code Online (Sandbox Code Playgroud)

但我的其他功能工作得很好.这只是我的HTML文件中的这个按钮不起作用.

<form name="AddNewUser" action="/ac/AddNewUser" method="post"> {% csrf_token %} <input type="submit" name="addNewUser" id="addNewUser" value="Create User"></form>

正如你所看到的,我已经得到了{%csrf_token%},但它仍然没有用.我也知道有些人在他们的settings.py中没有MIDDLEWARE_CLASSES但是我已经正确插入了这个问题.什么可能导致这个问题?错误中唯一的另一行说:"视图函数使用RequestContext作为模板,而不是Context." 但我不知道这意味着什么.

Joh*_*n C 11

您必须使用RequestContext对象来获取上下文,然后将结果传递给render_to_response()函数.RequestContext添加了必需的CSRF令牌.

from django.template import RequestContext
from django.shortcuts import render_to_response

csrfContext = RequestContext(request)
return render_to_response(some_template, csrfContext)
Run Code Online (Sandbox Code Playgroud)

作为旁注,您还可以使用RequestContext添加用于模板的上下文/字典.例如,我经常使用:

initialData = {'form': theForm, 'user_status': 'online'}
csrfContext = RequestContext(request, initialData)
return render_to_response(show_template, csrfContext)
Run Code Online (Sandbox Code Playgroud)

作为RequestContext做什么的(简要)解释:大多数中间件创建称为上下文处理器的东西,它只是一个提供变量上下文(字典)的函数.RequestContext查找所有可用的上下文处理器,获取它们的上下文,并将它们全部附加到单个(巨型)上下文.