1

私の「投稿」アクションはすべて「取得」として認識されています。これを修正するために知っていることはすべて試しましたが、すべてが正常に行われているようです。フォームを送信すると、毎回「GET」が返されます。

urls.py

from django.conf.urls.defaults import *
urlpatterns = patterns('',
 url(r'^buildit/$', 'main.apps.builder.views.main'),
)

views.py

from django.http import HttpResponse

def main(request):
  return HttpResponse(request.method)

htmlフォーム

<form id="myform">
<input type="checkbox" name="list" value="audio"/> Audio<br />
<input type="checkbox" name="list" value="video"/> Video<br />
<input type="submit" value="Get Custom Library!" /> 
</form>

jquery

$(document).ready(function() {

$("#myform").submit(function() {



    serialize = $(this).serialize()

    $.ajax({
    type: 'POST',
    url: '/django/builder/buildit',
    data: serialize,
    crossDomain: false,
    success: function(response){
        alert(response);
    }
});

    return false;

    $(document).ajaxSend(function(event, xhr, settings) {
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;
}
function sameOrigin(url) {
    // url could be relative or scheme relative or absolute
    var host = document.location.host; // host + port
    var protocol = document.location.protocol;
    var sr_origin = '//' + host;
    var origin = protocol + sr_origin;
    // Allow absolute or scheme relative URLs to same origin
    return (url == origin || url.slice(0, origin.length + 1) == origin + '/') ||
        (url == sr_origin || url.slice(0, sr_origin.length + 1) == sr_origin + '/') ||
        // or any other URL that isn't scheme relative or absolute i.e relative.
        !(/^(\/\/|http:|https:).*/.test(url));
}
function safeMethod(method) {
    return (/^(GET|HEAD|OPTIONS|TRACE)$/.test(method));
}

if (!safeMethod(settings.type) && sameOrigin(settings.url)) {
    xhr.setRequestHeader("X-CSRFToken", getCookie('csrftoken'));
}
});

});
});
4

2 に答える 2

2

あなたの形にそれを入れたほうがいいかもしれません

<form id="myform" method="post">

奇妙にインデントされたJavaScriptを読むのは難しいです。return false;しかし、送信コールバックを閉じずにコードがあるのはなぜですか?

于 2012-06-14T03:33:16.007 に答える
2

今、私はここでDjangoの専門家ではありません...しかし、Append_Slashの問題がある場合、Djangoはすべてのリクエストをオーバーライドするようです。最後にスラッシュを追加してリクエストをリダイレクトします。この時点で、POST情報はすべて失われ、GETメソッドが返されます。たぶん/django/ builder / builditの最後に/を付けてみてください?暗闇で撮影...(これはAPPEND_SLASH = falseの場合にのみ問題になるようです...)

于 2012-06-14T04:10:07.187 に答える