var_dump($_POST), возвращающий массив (0){} для строкового JSON, переданного с помощью jQuery AJAX

Привет, я не могу заставить этот пост работать. Сначала я использовал Typescript для создания класса:

class ParticipantInfo {

constructor (public fname: string,
             public mname: string,
             public lname: string,
             public ssn: string,
             public sin: string,
             public tin: string,
             public addr1: string,
             public addr2: string,
             public addr3: string,
             public city: string,
             public state: string,
             public zip: string,
             public email: string,
             public phone: string,
             public local: string){}
}

Который создал этот JavaScript:

var ParticipantInfo = (function () {
    function ParticipantInfo(fname, mname, lname, ssn, sin, tin, addr1, addr2, addr3, city, state, zip, email, phone, local) {
    this.fname = fname;
    this.mname = mname;
    this.lname = lname;
    this.ssn = ssn;
    this.sin = sin;
    this.tin = tin;
    this.addr1 = addr1;
    this.addr2 = addr2;
    this.addr3 = addr3;
    this.city = city;
    this.state = state;
    this.zip = zip;
    this.email = email;
    this.phone = phone;
    this.local = local;
    }
    return ParticipantInfo;
}());

Я использовал jQuery для обработки события submit для кнопки HTML, которую я прикрепил к элементу формы:

$(document).ready(function(){
    $("#frmInquiryForm").submit(function(event){

        event.preventDefault();

        var formData = new ParticipantInfo($('[name="f1_fname"]').val(),
                                           $('[name="f1_mname"]').val(),
                                           $('[name="f1_lname"]').val(),
                                           $('[name="f1_ssn"]').val(),
                                           $('[name="f1_sin"]').val(),
                                           $('[name="f1_tin"]').val(),
                                           $('[name="f1_addr1"]').val(),
                                           $('[name="f1_addr2"]').val(),
                                           $('[name="f1_addr3"]').val(),
                                           $('[name="f1_city"]').val(),
                                           $('[name="f1_state"]').val(),
                                           $('[name="f1_zip"]').val(),
                                           $('[name="f1_email"]').val(),
                                           $('[name="f1_phone"]').val(),
                                           $('[name="f1_local"]').val());
$.ajax({
            type: "POST",
            url:"processForm.php",
            data: JSON.stringify(formData),
            success: function(data){
                alert(data);
                window.location = 'confirmForm.php?message='+data;
            },
            error: function(xhr, ajaxOptions, thrownError){
                alert('status='+ajaxOptions);
                alert("XHR STATUS="+xhr.status+" "+ thrownError);

            }

        });

    })
})

Просто для тестирования все, что я делаю на странице processForm.php, это:

<?php
    var_dump($_POST);
?>

Предупреждающее сообщение от успешного вызова AJAX возвращает только "массив (0){}". Проблема в JSON.stringify или о чем-то еще кто-нибудь знает? Заранее спасибо за вашу помощь!

1 ответ

Решение

Удалить JSON.stringify перед отправкой ваших данных.

Вы не указываете contentType в $.ajax вызов, документ говорит, что по умолчанию application/x-www-form-urlencoded, JQuery кодирует ваши данные в foo=bar&this=that если вы передаете объект ему, но здесь вы передаете закодированную строку json, таким образом вызывая неожиданное поведение, которое для меня, вероятно, заключается в том, что php получает что-то вроде "{"foo":"bar"}", в то время как php только авторазбор urlencoded тело запроса (потому что отформатированное тело json является относительно новым в стандарте).

Так что если вы хотите использовать application/jsoncontent-typeубедитесь, что вы указали это в $.ajaxи разбери его в php как $requestArray = json_decode(file_get_contents('php://input'));, Подробнее читайте в другом вопросе здесь.

Другие вопросы по тегам