0

単純な文字列化された int 配列を json 式に渡して、ajax 経由で送信しようとしています。リクエストの URL とヘッダーはすべて、クライアントからサーバーに移動するのに問題ないように見えますが、Cake では、何らかの理由で request->query vardumps が空です。

ajax からのヘッダー:

Request URL:http://localhost/cakephp-2.2.5/paragraphs/sortPublished.json?[%221%22,%223%22,%222%22]
Request Method:GET
Status Code:200 OK
Request Headersview source
Accept:application/json, text/javascript, */*; q=0.01
Accept-Charset:ISO-8859-1,utf-8;q=0.7,*;q=0.3
Accept-Encoding:gzip,deflate,sdch
Accept-Language:fi-FI,fi;q=0.8,en-US;q=0.6,en;q=0.4
Connection:keep-alive
Content-Type:application/json; charset=utf-8
Cookie:CAKEPHP=gu46lhu6lohe1hnr4vmeve23g1
DNT:1
Host:localhost
Referer:http://localhost/cakephp-2.2.5/paragraphs/edit/1
User-Agent:Mozilla/5.0 (Windows NT 6.0) AppleWebKit/537.31 (KHTML, like Gecko) Chrome/26.0.1410.64 Safari/537.31
X-Requested-With:XMLHttpRequest
Query String Parametersview sourceview URL encoded
["1","3","2"]:
Response Headersview source
Connection:Keep-Alive
Content-Length:425
Content-Type:application/json; charset=UTF-8
Date:Mon, 13 May 2013 09:11:14 GMT
Keep-Alive:timeout=5, max=98
Server:Apache/2.4.3 (Win32) OpenSSL/1.0.1c PHP/5.4.7
X-Powered-By:PHP/5.4.7

そしてジャバスクリプト

$(document).ready(function(){
$("#button").click(function() {
    var sortedParagraphs = $( "#sortable1" ).sortable('toArray');

    var key_value_pairs = [];
    var i = 0;
    $.each( sortedParagraphs, function(index, value) {
        key_value_pairs[index] = value;
    });

    $.ajax({
      url: define1,
      data: JSON.stringify(sortedParagraphs),
      dataType: "json",
      contentType: 'application/json; charset=utf-8',
      success: function(data) {
        alert(data);
      }
    });
});
});

私のアマチュアの自己にとって、JSON が正しく形成されていることは明らかであり、URL に問題は見られませんが、request->query は引き続き生成されます。

array(0) {
}

私は永遠に感じるので、この小さな問題に取り組んできました。

4

1 に答える 1

1

まず第一に、変数を「文字列化」する必要はありません。jQuery が既に処理しています。

配列を文字列化しているため、jQuery は配列のリテラル文字列表現を送信します。すなわち'["1","3","2"]'。基本的に、クエリ パラメータの名前は '["1","3","2"]' で、は設定されていません。

次に、送信するデータに「名前」を割り当てていないため、CakePHP には読み取るクエリ パラメータがありません。

これを試して;

$.ajax({
   url: define1,
   data: {paragraphs: sortedParagraphs},
   dataType: "json",
   contentType: 'application/json; charset=utf-8',
   success: function(data) {
     alert(data);
   }
 });

そしてあなたのコントローラーの中に;

debug($this->request->query);

次のようなものを出力する必要があります

array(
    'paragraphs' => array(
        (int) 0 => '1',
        (int) 1 => '3',
        (int) 2 => '2'
    )
)

追加の簡素化

はすでに配列を返しているため$( "#sortable1" ).sortable('toArray');、( を使用して)結果を手動で配列に変換する必要はありません$.each(...。したがって、これはおそらくまったく同じ結果になります。

$("#button").click(function() {
    $.ajax({
       url: define1,
       data: {paragraphs: $("#sortable1").sortable('toArray')},
       dataType: "json",
       contentType: 'application/json; charset=utf-8',
       success: function(data) {
         alert(data);
       }
     });
}
于 2013-05-13T11:26:54.097 に答える