为什么在处理POST数据后重定向很重要?

时间:2014-01-13 03:53:55

标签: django redirect

此代码来自Django documentation on forms

from django.shortcuts import get_object_or_404, render
from django.http import HttpResponseRedirect, HttpResponse
from django.core.urlresolvers import reverse
from polls.models import Choice, Poll

def vote(request, poll_id):
    p = get_object_or_404(Poll, pk=poll_id)
try:
    selected_choice = p.choice_set.get(pk=request.POST['choice'])
except (KeyError, Choice.DoesNotExist):
    # Redisplay the poll voting form.
    return render(request, 'polls/detail.html', {
        'poll': p,
        'error_message': "You didn't select a choice.",
    })
else:
    selected_choice.votes += 1
    selected_choice.save()
    # Always return an HttpResponseRedirect after successfully dealing
    # with POST data. This prevents data from being posted twice if a
    # user hits the Back button.
    return HttpResponseRedirect(reverse('polls:results', args=(p.id,)))

我正在学习Django框架,我无法理解为什么在处理POST数据后重定向对于安全性很重要。

实际上下面有一个解释:

  

成功处理后始终返回HttpResponseRedirect      使用POST数据。如果a,这可以防止数据被发布两次      用户点击后退按钮。

有人可以进一步解释这个吗?

1 个答案:

答案 0 :(得分:0)

这意味着用户可以点击F5(Back-Sumbit)(Back-Sumbit)(Back-Sumbit)

多次发布

如果不是返回重定向?

我认为它有助于防止灌溉。