1. ホーム
  2. ajax

[解決済み] データをリクエストペイロードではなく、フォームデータとして投稿するにはどうすればよいですか?

2022-03-18 14:09:46

質問

以下のコードでは、AngularJSの $http メソッドは URL を呼び出し、xsrf オブジェクトを "Request Payload" として送信します (Chrome デバッガーのネットワーク タブで説明されています)。jQuery の $.ajax メソッドは同じ呼び出しを行いますが、xsrf を "フォームデータ" として送信します。

AngularJSでxsrfをリクエストペイロードではなく、フォームデータとして送信するにはどうすればよいですか?

var url = 'http://somewhere.com/';
var xsrf = {fkey: 'xsrf key'};

$http({
    method: 'POST',
    url: url,
    data: xsrf
}).success(function () {});

$.ajax({
    type: 'POST',
    url: url,
    data: xsrf,
    dataType: 'json',
    success: function() {}
});

解決方法は?

渡される$httpオブジェクトに、以下の行を追加する必要があります。

headers: {'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'}

そして、渡されたデータは、URLエンコードされた文字列に変換される必要があります。

> $.param({fkey: "key"})
'fkey=key'

というようなものがあるんですね。

$http({
    method: 'POST',
    url: url,
    data: $.param({fkey: "key"}),
    headers: {'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'}
})

からです。 https://groups.google.com/forum/#!msg/angular/5nAedJ1LyO0/4Vj_72EZcDsJ

アップデイト

AngularJS V1.4で追加された新サービスを利用するには