如何从PHP脚本获取JSON变量

时间:2012-12-18 08:44:41

标签: php jquery ajax json

我遇到了问题:

我有一个JS函数,它将数据发送到php脚本,然后PHP脚本从数据库QUERY返回JSON数据,我想从PHP脚本返回值。

<script type="text/javascript">
    <!--

    jQuery('#wysz2').submit(function() {


        var myData = {
            "rodzaj_konta": jQuery('#rodzaj_konta').val(),
            "miejscowosc": jQuery('#miejscowosc').val()
        };

        jQuery.ajax({
            url: 'http://somescript.php?action=results',
            type: 'GET',
            data: myData,
            dataType: 'json',
            beforeSend: function() {
                jQuery('#loading').html('<p>loading...</p><img src="loading.gif" />'); //Loading image during the Ajax Request
            },
            error: function(xhr, textStatus, errorThrown) {
                alert("Error: " + (errorThrown ? errorThrown : xhr.status));
            },
            contentType: "application/json; charset=utf-8",
            success: function(data) {

                alert(data);
            }


        });

        return false;

    });
    //-->​
</script>

PHP脚本使用以下方式以适当的格式返回数据:

header('Content-Type: application/json');
echo json_encode($data);

当我试图提醒(数据)时,我总是得到一个空值。

如何获取此返回的JSON数据?

编辑:

这很奇怪,因为我已经将发送方法更改为POST。

PHP返回JSON:

[{"nazwa":"Test","nazwa_firmy":"Testowa","ulica":null,"numer_domy":"2A","numer_mieszkania":"11","kod_pocztowy":"00-189","miejscowosc":"Warszawa","telefon":"213-123-132","nip":"112-312-31-31","regon":"231232133","adres_www":"http:\/\/www.gogl.epl","rodzaj_uzytkownika":"serwis"}]

但我的JQUERY AJAX脚本仍然返回null。

所以我的脚本现在看起来像这样:

<script type="text/javascript">
                <!--

                    jQuery('#wysz2').submit(function() {




                    var myData = {
                       rodzaj_konta: jQuery('#rodzaj_konta').val(),
                        miejscowosc: jQuery('#miejscowosc').val()
                    };



                    jQuery.ajax({
                        url: 'http://somedomain.com/skrypt.php?action=wyniki_wyszukiwania',
                        type: 'GET',
                        data: myData,
                        dataType: 'json',
                        contentType: "application/json; charset=utf-8",
                        jsonp: "jsoncallback",
                        beforeSend:  function() {
                            jQuery('#loading').html('<p>ładowanie...</p><img src="loading.gif" />');//Loading image during the Ajax Request
                        },
                        error: function (xhr, textStatus, errorThrown) {
                            alert("Error: " + (errorThrown ? errorThrown : xhr.status));
                        },
                        success: function (data) {
                            alert(JSON.stringify(data));
                            console.log(data);
                        }

                    });

                    return false;

                });
                //-->
                </script>

有什么想法吗?

3 个答案:

答案 0 :(得分:0)

你正在以错误的方式发送你的变量根据定义不存在对象名的半光数

试试这个

var myData = {
           rodzaj_konta: jQuery('#rodzaj_konta').val(),
            miejscowosc: jQuery('#miejscowosc').val()
        };

并在提醒您的json数据时尝试

alert(JSON.stringify(your_json_obj));

答案 1 :(得分:0)

尝试提醒结果对象......

表示json的格式为{“responseCode”:“001”,“responseMsg”:“success”}

然后提醒data.responseCode

答案 2 :(得分:0)

你的ajax功能成功尝试这样的事情      var objParams1 = $.parseJSON(data); console.log(objParams1); alert(objParams1.Testowa)