Ajax post数组(空)

时间:2015-08-08 21:53:29

标签: jquery ajax laravel

我试图通过ajax调用发布一个关联数组,但我发送的数组总是空的(chrome network debug)

我的ajax电话

function getAssurance(passagers)
{
    console.log(passagers);

    var postdata =  JSON.stringify({psg:passagers});

    $.ajax({
        dataType: "json",
        url: rootUrl + "/b2c/searchAssurance",
        data: postdata,
        type: "POST",
        success:function(result) {
            console.log(result);
        },
        error: function (jqXHR, textStatus, errorThrown) {
            alert(textStatus);
        }
    }); 
} 

我的console.log()

中的数组是正确的

我的路线

Route::post('/b2c/searchAssurance', 'VolControllerB2C@searchAssurance');

我的控制器

 public function searchAssurance()
    {
        $search_data = Input::get('psg');

        log::error(print_r($search_data,true));

        echo "ok";
    }

我在哪里构建我的数组

var valide = true;
            var psgDetails = [];

            if($("#country").val() == "-1")
            {
                valide = false;
            }

            if($("#state").val() == "0")
            {
                valide = false;
            }

            if($("#phone_0").val() == "0")
            {
                valide = false;
            }

            if(valide)
            {
                for(var i = 0; i<$("#nb").val(); i++)
                {
                    var onePsg = [];

                    if(i==0)
                    {
                        onePsg['country'] = $("#country").val();
                        onePsg['state'] = $("#state").val();
                        onePsg['phone_0'] = $("#phone_0").val();
                    }

                    if($("#title_"+i).val() == "0")
                    {
                        valide = false;
                    }

                    if($("#name_"+i).val().length < 1)
                    {
                        valide = false;
                    }

                    if($("#lastname_"+i).val().length < 1)
                    {
                        valide = false;
                    }

                    if($("#dob_day_"+i).val() == "Day")
                    {
                        valide = false;
                    }

                    if($("#dob_month_"+i).val() == "Month")
                    {
                        valide = false;
                    }

                    if($("#dob_year_"+i).val() == "Year")
                    {
                        valide = false;
                    }

                    onePsg["title"] = $("#title_"+i).val();
                    onePsg['name'] = $("#name_"+i).val();
                    onePsg['lastname'] = $("#lastname_"+i).val();
                    onePsg['dob_day'] = $("#dob_day_"+i).val();
                    onePsg['dob_month'] = $("#dob_month_"+i).val();
                    onePsg['dob_year'] = $("#dob_year_"+i).val();

                    psgDetails.push(onePsg);
                }
            }

            if(valide)
            {
                console.log(psgDetails);
                getAssurance(psgDetails);
                $("#assurance").show("slow");
                $("#assuranceArrow").toggleClass('arrow-down arrow-up');
                $("html, body").animate({scrollTop: $('#assurance').offset().top }, 200);
            }

任何人都知道我做错了什么?

2 个答案:

答案 0 :(得分:0)

我不知道你正在使用哪个框架但是...... 在您的后端方法中,您似乎使用获取接收数据,但是您使用发布来使用jQuery发送数据:


    public function searchAssurance()
        {
            // HERE you should use "post" to receive the data in your framework
            $search_data = Input::get('psg');
        }

注意:如果您使用的是Laravel,我的回答是不正确的,因为Input :: get用于所有HTTP谓词;

答案 1 :(得分:0)

我不知道这是否是唯一的问题,但在通过ajax发送之前不要对变量进行字符串化:

function getAssurance(passagers)
{
    console.log(passagers);

    //don't: var postdata =  JSON.stringify({psg:passagers});

    $.ajax({
        dataType: "json",
        url: rootUrl + "/b2c/searchAssurance",
        data: postdata,
        type: "POST",
        success:function(result) {
            console.log(result);
        },
        error: function (jqXHR, textStatus, errorThrown) {
            alert(textStatus);
        }
    }); 
}