簡體   English   中英

“用戶警告:模板中使用了{%csrf_token%}” views.py無法識別“ RequestContext”?

[英]“UserWarning: A {% csrf_token %} was used in a template” views.py not recogniseing “RequestContext”?

我正在研究django-floppyforms的實現,特別是滑塊widget 但是我無法讓它顯示在我的Django Web應用程序中。 本機滑塊可以工作,但jQuery滑塊不能工作。 下圖顯示了問題。

在此處輸入圖片說明

錯誤

> UserWarning: A {% csrf_token %} was used in a template, but the
> context did not provide the value.  This is usually caused by not
> using RequestContext.   warnings.warn("A {% csrf_token %} was used in
> a template, but the context did not provide the value.  This is
> usually caused by not using RequestContext.")

該課題這個問題而這個問題的所有建議作出肯定的django.core.context_processors.csrf背景處理器使用的解決方案之一是使用RequestContextdjango.template

如您在下面看到的,我嘗試實現它,但是它一直給我同樣的錯誤。

有任何想法嗎?

  • Django的== 1.6.2
  • Django的floppyforms == 1.2.0

views.py

def sview(request):
   jquery_slider = Slider()
   native_slider = SlideForm()

   return render_to_response('slider_one.html', {
                                          'jquery_slider': jquery_slider,   
                                          'native_slider': native_slider,             
                                          }, context_instance=RequestContext(request))

slider_one.html

{# slider.html #}
{% include "floppyforms/input.html" %}
<div id="{{ attrs.id }}-slider"></div>

<html> 
    <body>
        <h1>This is your slider_one.html template</h1>

<script type="text/javascript" src="{{ STATIC_URL }}/js/jquery.min.js"></script> 
<script type="text/javascript" src="{{ STATIC_URL }}/js/jquery-ui.min.js"></script> 
<script type="text/javascript" src="{{ STATIC_URL }}/css/jquery-ui.min.css"></script> 


<form action="" method="post">
    {% csrf_token %}

        {{ jquery_slider }}
        {{ native_slider }}

    <input type="submit" value="Submit" />               
</form>

<script type="text/javascript">
  $(document).ready(function() {
    var type = $('<input type="range" />').attr('type');
    if (type == 'text') { // No HTML5 support
      $('#{{ attrs.id }}').attr("readonly", true);
      $('#{{ attrs.id }}-slider').slider({
        {% if value %}value: {{ value }},{% endif %}
        min: {{ attrs.min }},
        max: {{ attrs.max }},
        step: {{ attrs.step }},
        slide: function(event, ui) {
          $('#{{ attrs.id }}').val(ui.value);
        }
      });
    }
  });
</script>

forms.py

import floppyforms as forms    

class Slider(forms.RangeInput):
    min = 5
    max = 20
    step = 5
    template_name = 'slider_one.html'

    class Media:
        js = (
            '/static/js/jquery.min.js',
            '/static/js/jquery-ui.min.js',
        )
        css = {
            'all': (
                '/static/css/jquery-ui.css',
            )
        }

class SlideForm(forms.Form):
    num = forms.IntegerField(widget=Slider)

    def clean_num(self):
        num = self.cleaned_data['num']
        if not 5 <= num <= 20:
            raise forms.ValidationError("Enter a value between 5 and 20")

        if not num % 5 == 0:
            raise forms.ValidationError("Enter a multiple of 5")
        return num

編輯:

我也在settings.py文件的MIDDLEWARE_CLASSES中啟用了以下功能

django.middleware.csrf.CsrfViewMiddleware'

我有同樣的問題。 正如@professorDante所說,您需要:

return render(request, "slider_one.html", local())

關鍵是必須將請求對象傳遞給模板才能生成csrf。

嘗試使用render()快捷方式-您要使用RequestContext,並且該方法默認使用一個。 如果可行,您就知道它是return_to_render的實現。

from django.shortcuts import render 

return render(request, "slider_one.html",{'jquery_slider':jquery_slider,'native_slider':native_slider})

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM