gpt4 book ai didi

python - Django --CSRF token 缺失或不正确

转载 作者:行者123 更新时间:2023-12-02 09:58:26 43 4
gpt4 key购买 nike

所以我收到 Forbidden (403) CSRF 验证失败。请求被中止。失败原因:CSRF token 丢失或不正确。
我的 middleware_classes 中有“django.middleware.csrf.CsrfViewMiddleware”。这是我的模板

<form name="input" action="/login/" method="Post"> {% csrf_token %}
<input type="submit" value="Submit"></form>

这是我的观点

from django.shortcuts import render_to_response
from django.core.context_processors import csrf
from django.template import RequestContext
def login(request):
csrfContext = RequestContext(request)
return render_to_response('foo.html', csrfContext)

嗯,我是 Django 和大多数 Web 开发的新手,但我似乎找不到这里的问题。任何帮助将不胜感激!

我也尝试过django文档中的方法

c = {}
c.update(csrf(request))
# ... view code here
return render_to_response("a_template.html", c)

最佳答案

我和你遇到了同样的问题,我发现这段代码可以解决我的问题。

from django.views.decorators.csrf import csrf_exempt
from django.shortcuts import render
from django.contrib import auth

#in accounts.forms i've placed my login form with two fields, username and password
from accounts.forms import LoginForm

@csrf_exempt
def login(request):
if request.method == "POST":
form = LoginForm(request.POST)
if form.is_valid():
user = auth.authenticate(
username=form.cleaned_data["username"],
password=form.cleaned_data["password"])
auth.login(request, user)
return HttpResponseRedirect("/")
else:
form = LoginForm()

return render(request, 'accounts/login.html', {'form':form})

关于python - Django --CSRF token 缺失或不正确,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12731305/

43 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com