Django CRSF令牌丢失或不正确
我得到一个403禁止的错误。我已经尝试过做论坛上已经解释过的上下文内容,但我仍然处于第一步 我做错了什么?我的观点Django CRSF令牌丢失或不正确,django,django-forms,Django,Django Forms,我得到一个403禁止的错误。我已经尝试过做论坛上已经解释过的上下文内容,但我仍然处于第一步 我做错了什么?我的观点 def add_player(request, team_id): template = get_template('cricket/addplayer.html') loggedinuser = request.user team = Team.objects.get(id=team_id) if request.method== 'POST':
def add_player(request, team_id):
template = get_template('cricket/addplayer.html')
loggedinuser = request.user
team = Team.objects.get(id=team_id)
if request.method== 'POST':
form = PlayerForm(request.POST)
if form.is_valid():
player = Player.objects.create(
name = form.cleaned_data['name'],
team = Team.objects.get(id=team_id),
role = form.cleaned_data['role'],
position = form.cleaned_data['position']
)
return HttpResponseRedirect('/team/%s/' % team_id)
else:
form = PlayerForm
page_vars = Context({
'form': form,
'loggedinuser': loggedinuser,
'team': team,
})
output = template.render(page_vars)
return HttpResponse(output)
还有我的模板。如您所见,它拥有{%csrf_token%}
{% extends 'cricket/base.html' %}
{% block title %}
{{ loggedinuser }}
{% endblock %}
{% block username %}
{{ loggedinuser }}
{% endblock %}
{% block date %}
{{ today }}
{% endblock %}
{% block content %}
<div class="span7">
<h2>Adding player for {{ team }}</h2>
<form method="post" action=".">
{% csrf_token %}
{{ form.as_p }}
<input type="submit">
</form>
</div>
{% endblock %}
您还可以在django中使用基于类的泛型视图。 在你的情况下可能是这样的:(我没有测试过) url.py
urlpatterns = patterns('',
url(r'^your-url/(?P<teamId>\d+)/$', AddPlayerView.as_view(), name="add-player"),
)
尝试使用render_to_response函数,而不是带有某些RequestContext的HttpResponse。鼠标您好,很高兴您解决了问题。与其编辑问题以包含解决方案,不如将其作为单独的答案添加。通过这种方式,其他用户可以投票,您可以将其标记为已接受,这样其他用户就可以看到您找到了答案。您可以在视图中使用更干净的代码。我无法回答自己的问题,不得不等待8个小时。
urlpatterns = patterns('',
url(r'^your-url/(?P<teamId>\d+)/$', AddPlayerView.as_view(), name="add-player"),
)
from django.views.generic import FormView
from django.core.urlresolvers import reverse
.....
class AddPlayerView(FormView):
template_name = 'cricket/addplayer.html'
form_class = PlayerForm
def form_valid(self, form):
""" Code if the form is valid """
...
player = Player.objects.create(
name = form.cleaned_data['name'],
team = Team.objects.get(id=form.cleaned_data['team_id']),
role = form.cleaned_data['role'],
position = form.cleaned_data['position']
)
# You could use url reverse here
url = reverse('your-view-name', args=[form.cleaned_data['team_id']])
return HttpResponseRedirect(url)
def form_invalid(self, form):
""" Code if the form is invalid """
.....
def get_context_data(self, **kwargs):
context = super(AddPlayerView, self).get_context_data(**kwargs)
loggedinuser = self.request.user
team = Team.objects.get(id=self.kwargs['teamId'])
context['loggedinuser'] = loggedinuser
context['team'] = team
return context