python - 在网站文件中消失 {% csrf_token %}

标签 python html django django-templates pythonanywhere

当我想在我的网站上使用我的注册表时,我收到错误 403:“CSRF 验证失败。请求已中止。”在本网站的源代码中,我意识到它丢失了。这是我网站上查看源代码的一部分:

<div style="margin-left:35%;margin-right:35%;">
<fieldset>
<legend> Wszystkie pola oprócz numeru telefonu należy wypełnić </legend>
    <form method="post" action=".">
        <p><label for="id_username">Login:</label> <input id="id_username" maxlength="30" name="username" type="text" required/></p>
<p><label for="id_email">Email:</label> <input id="id_email" name="email" type="email" required /></p>
<p><label for="id_password1">Hasło:</label> <input id="id_password1" name="password1" type="password" required /></p>
<p><label for="id_password2">Powtórz hasło:</label> <input id="id_password2" name="password2" type="password" required /></p>
<p><label for="id_phone">Telefon:</label> <input id="id_phone" maxlength="20" name="phone" type="text" /></p>
<p><label for="id_log_on">Logowanie po rejestracji:</label><input id="id_log_on" name="log_on" type="checkbox" /></p>
        <input type="submit" value="Rejestracja"><input type="reset" value="Wartości początkowe">
    </form>
</fieldset>
</div>

我对此感到惊讶,因为在我的 Pythonanywhere 文件中存在这段代码。

这是我在 Pythonanythere 上的文件 register.html 的一部分:

<div style="margin-left:35%;margin-right:35%;">
<fieldset>
<legend> Wszystkie pola oprócz numeru telefonu należy wypełnić </legend>
    <form method="post" action=".">{% csrf_token %}
        {{ form.as_p }}
        <input type="submit" value="Rejestracja"><input type="reset" value="Wartości początkowe">
    </form>
</fieldset>
</div>

我的网页看不到这段代码,我做错了什么?它在服务器上缝合但在网页上查看源代码它不是。

编辑: 这是呈现我的模板的 View :

def register(request):
    if request.method == 'POST':
    form = FormularzRejestracji(request.POST)
    if form.is_valid():
        user = User.objects.create_user(
            username=form.cleaned_data['username'],
            password=form.cleaned_data['password1'],
            email=form.cleaned_data['email']
        )
        user.last_name = form.cleaned_data['phone']
        user.save()
        if form.cleaned_data['log_on']:
            user = authenticate(username=form.cleaned_data['username'], password=form.cleaned_data['password1'])
            login(request, user)
            template = get_template("osnowa_app/point_list.html")
            variables = RequestContext(request, {'user': user})
            output = template.render(variables)
            return HttpResponseRedirect("/")
        else:
            template = get_template("osnowa_app/register_success.html")
            variables = RequestContext(request, {'username': form.cleaned_data['username']})
            output = template.render(variables)
            return HttpResponse(output)

else:
    form = FormularzRejestracji()
template = get_template("osnowa_app/register.html")
form = FormularzRejestracji()
variables = RequestContext(request, {'form': form})
output = template.render(variables)
return HttpResponse(output)

最佳答案

您应该将普通字典和请求对象传递给 template.render(),而不是 RequestContext。模板引擎将为您将其转换为 RequestContext:

template = get_template("osnowa_app/register.html")
context = {'form': form}
output = template.render(context, request)

现在,template.render() 函数将类似字典的对象视为第一个参数,但没有请求作为第二个参数。如果没有将请求作为第二个参数,它将类似字典的 RequestContext 转换为普通的 Context 对象。由于 Context 对象不运行上下文处理器,因此您的上下文缺少 csrf token 。

或者你可以只使用 render shortcut ,它返回一个 HttpResponse 对象,内容是呈现的模板:

from django.shortcuts import render

def register(request):
    ...
    return render(request, "osnowa_app/register.html", {'form': form})

这个特殊案例也在 ticket #27258 中讨论。 .

关于python - 在网站文件中消失 {% csrf_token %},我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39849875/

相关文章:

python - Pandas 根据多个条件过滤行

Python:通过加窗的高通 FIR 滤波器

python - 来自 Django 测试的错误 404?

python - Django:登录链接仅在用户登录时出现

javascript - django模板-日期格式问题

python - 如何为具有未知数量变量的 python 函数定义创建正则表达式?

java - 我如何在java servlet中读取html anchor ?

html - 如何在 flexbox 的同一行对齐文本?

html - 如何编辑水平下拉菜单

python - 在分组变量中按先前值(年份)标记滚动重复项