403 Запрещено и request.method показывает GET в Django

Я пытаюсь отправить данные формы в приложение, используя AJAX.

Javascript часть:

function submit_changes() {
var all_data = [A_list, B_list,C_list]
$.ajax({
    type: "POST",
    url: "/my_url/",
    contentType: "application/json",
    //dataType: 'json',
    //data:JSON.stringify(all_data),
data:{
    csrfmiddlewaretoken: "{{ csrf_token }}",        
    form:JSON.stringify(all_data),
},

  success: function() {
        alert('Data captured successfully');
        //window.location.reload();
    },
    error: function(){
        alert('Error in data capture')
        //window.location.reload();
    }
});
}

urls.py имеет это

urlpatterns=[url(r'^my_url/$',views.my_url_fn)]

views.py

def my_url_fn(request):
    print "*** request is ***",request
    if request.method == 'POST':
        print "request is POST"
        return Response(json.dumps(submit_changes(request)))
    elif request.method == 'GET':
        print "request is GET"
        return Response(json.dumps(get_already_present_data()),mimetype='application/json')
    else:
        print "neither post nor get"

Часть формы из HTML-кода:

<div align="center">
  <form name="myForm" onSubmit="return 0">{% csrf_token %}    
    <input type="text" id="blah1" placeholder="Blah1&hellip;">
        <!-- few more fields -->
  </form> 
</div>
<div align='center'>
  <input id="submit_changes" type="button" align="middle" value="Submit Changes" onclick="submit_changes();" />
</div>

Я загрузил JavaScript в HTML. Я получаю 403 запрещенную ошибку и request.method печатает GET.

У меня есть две вещи, чтобы спросить:

1). Почему request.method GET, когда это POST-запрос?

2). Почему я по-прежнему получаю ошибку 403 даже после выдачи токена csrf?

Я много искал и пробовал это: Добавление @csrf_exempt выше моего взгляда и импортировать его как from django.views.decorators.csrf import csrf_exempt, Без улучшения. Я также пытался удалить django.middleware.csrf.CsrfViewMiddleware от MIDDLEWARE список в моем settings.py. По-прежнему нет прогресса! У меня есть еще один вопрос здесь. Означает ли это, что изменения в settings.py не отражаются? Любая помощь будет принята с благодарностью!

2 ответа

Решение

Вы можете попробовать это

<script type="text/javascript">

    function getCookie(name) {
        var cookieValue = null;
        if (document.cookie && document.cookie !== '') {
            var cookies = document.cookie.split(';');
            for (var i = 0; i < cookies.length; i++) {
                var cookie = jQuery.trim(cookies[i]);
                // Does this cookie string begin with the name we want?
                if (cookie.substring(0, name.length + 1) === (name + '=')) {
                    cookieValue = decodeURIComponent(cookie.substring(name.length + 1));
                    break;
                }
            }
        }
        return cookieValue;
    }
    var csrftoken = getCookie('csrftoken');
    $(document).ready(function () {
        $.ajax({
            type: 'post',
            url: "{% url "url_to_view" %}",
            headers: {"X-CSRFToken": csrftoken},
            data: {id: "something to view"},
            success: function (response) {
                alert("success");
                });
            },
            failure: function (response) {
                alert(response.d);
            }
        });
    });
</script>

Вам нужно сделать что-то подобное в JavaScript, чтобы правильно установить токен csrf. Не нужно часть данных, а заголовки запроса

function csrfSafeMethod(method) {
    // these HTTP methods do not require CSRF protection
    return (/^(GET|HEAD|OPTIONS|TRACE)$/.test(method));
}
$.ajaxSetup({
    beforeSend: function(xhr, settings) {
        if (!csrfSafeMethod(settings.type) && !this.crossDomain) {
            xhr.setRequestHeader("X-CSRF-Token", CSRF_TOKEN);
        }
    }
});

В django вам не нужно делать csrf_exempt, так как приведенный выше код будет вставлять токен CSRF в каждый запрос ajax, если это необходимо. (есть очень веская причина, по которой существует CSRF, поэтому лучше не освобождать его)

Другие вопросы по тегам