试图将ajax发布到django视图方法并完全失败

时间:2013-08-11 16:06:28

标签: ajax django csrf

我完全迷失了,我已经阅读了这个问题的一些答案和教程,包括关于django网站的信息,我不知道如何处理这个问题。

我的问题非常简单。我想用ajax做一个简单的帖子请求并获取一些信息。我甚至无法进入django方面的view方法。

这是代码

#urls.py
url(r'^spitback/$', 'spitback'),

#views.py
def spitback(request):
    logger.debug("\n\n\nspitback");
    logger.debug("request.method = {0}".format(request.method))
    return HttpResponse("helloooooo")

javascript:

function csrfSafeMethod(method) {
    return(/^(GET|HEAD|OPTIONS|TRACE)$/.test(method));
}

$.ajaxSetup({
    crossDomain: false,
    beforeSend: function(xhr, settings) {
        var csrftoken = $.cookie('csrftoken');

        if (!csrfSafeMethod(settings.type)) {
            xhr.setRequestHeader("X-CSRFToken", csrftoken);
        }
    }
});


function testpost() { 
  $.ajax({ 
    type:"POST", 
    url:'/login', 
    data:{
        'key':'val', 
       'csrfmiddlewaretoken':"TB5gktJzHdowOtXR4u1BpjGABoKbJ2IQ"
    },        
    contentType:"application/json;charset=utf-8", 
    dataType:"json", 
    success: function(data) { alert('data = ' + data);}, 
    error: function(ts) { alert('ts = ' + ts)}
  }); 

  return false; 
}

    $( document ).ready( function() {
        console.log("document loaded for template login.django");
         $( "#somebutton" ).click( 
            testpost
        );
    });

此时我只是想测试帖子功能,但是当我尝试一下时,我清楚地从日志中看到“spitback”的查看方法甚至没有被调用。

有人请帮帮我,我的智慧结束了。

1 个答案:

答案 0 :(得分:1)

应该是:

 $( "#somebutton" ).click( 
     testpost();
 );

你的ajax调用中的url也是错误的。