AJAXとJQueryを使用してJSONデータでPUTコールを実装する方法は?

いろいろな方法を試してみましたが、コントローラの関数に実際のデータを渡すことができません。

以下はそのコードです。

        var URL = "/Timesheet/Timesheet/UpdateEntry";

        var dataObject = { 'newWeekEntry': newEntry, 'oldWeekEntry': oldEntry };

        alert(JSON.stringify(dataObject));

        $.ajax({
            url: URL,
            type: 'PUT',    
            data: JSON.stringify(dataObject),
            dataType: 'json',
            success: function(result) {
                alert("success?");
            }
        });

newEntryoldEntry` は両方ともオブジェクトです。

alert` 行はこのように出力します (簡潔にするために、いくつかのプロパティを削除しています)。

{"newWeekEntry":{"MondayHours":2,"TuesdayHours":2,"WednesdayHours":5,"ThursdayHours":5,"FridayHours":"4","SaturdayHours":0,"SundayHours":0},"oldWeekEntry":{"MondayHours":2,"TuesdayHours":2,"WednesdayHours":5,"ThursdayHours":5,"FridayHours":2,"SaturdayHours":0,"SundayHours":0}}

コントローラのアクションをデバッグすると ("UpdateEntry") 、2つのパラメータに TimesheetEntry クラスのデフォルトパラメータ (0) が入力されています。

これは正しく渡せているのでしょうか?

ソリューション

dataType属性は、サーバーからデータを取得するときにのみ使用されます'。サーバにデータを送信する際には、contentTypeapplication/json` に設定しなければならない。

解説 (1)

ヘッダーは {"X-HTTP-Method-Override": "PUT"} で、リクエストタイプを POST にオーバーライドしてください。私のプロジェクトではうまくいきました...

$.ajax({
    type: 'POST', // Use POST with X-HTTP-Method-Override or a straight PUT if appropriate.
    dataType: 'json', // Set datatype - affects Accept header
    url: "http://example.com/people/1", // A valid URL
    headers: {"X-HTTP-Method-Override": "PUT"}, // X-HTTP-Method-Override set to PUT.
    data: '{"name": "Dave"}' // Some data e.g. Valid JSON as a string
});
解説 (3)
$.ajax({
        url: window.serverUrl + 'student/event/' + eventId,
        type: 'put',
        data: JSON.stringify(data),
        headers: {
            'x-auth-token': localStorage.accessToken,
            "Content-Type": "application/json"
        },
        dataType: 'json'
})

これは私の場合、うまくいきました

解説 (0)