需要帮助制定正确的JSON响应

时间:2014-05-22 11:21:26

标签: php jquery ajax json

我是一个使用Jquery ajax调用和json响应的新手,遇到了需要帮助才能解决的问题。

我正在使用cleeng open API,我想知道我正在使用的一个api调用的响应 - getRentalOffer()

我正在使用jquery $ ajax()请求,我想进行getRentalOffer()api调用并以JSON格式返回结果。到目前为止我的努力是这样的(假设一个带有id作为参数的POST请求。)

请求:

<script type="text/javascript">

    $(document).ready(function() {

        $( "#getOfferButton" ).click(function() {


            var offerId = document.frm.offerID.value;

            $.ajax({
                // the URL for the request
                url: "ajax-get-offer.php",

                // the data to send (will be converted to a query string)
                data: {
                    id: offerId
                },

                // whether this is a POST or GET request
                type: "POST",

                // the type of data we expect back
                dataType : "json",

                // code to run if the request succeeds;
                // the response is passed to the function
                success: function(json) {



                // $("#title").val = json.title;
                  /*
                   $.each(json, function(i, item){
                           $("#"+item.field).val(item.value);
                        }); 
                   */
                 console.log(json);

                },

                // code to run if the request fails; the raw request and
                // status codes are passed to the function
                error: function( xhr, status, errorThrown ) {
                    alert( "Sorry, there was a problem!" );
                    console.log( "Error: " + errorThrown );
                    console.log( "Status: " + status );
                    console.dir( xhr );
                },

                // code to run regardless of success or failure
                complete: function( xhr, status ) {
                    alert( "The request is complete!" );
                }
            });

        });
    });
    </script>

AJAX-GET-offer.php:

<?php
include_once('Cleeng-cleeng-php-sdk-fe2a543/cleeng_api.php');
/*
Using FirePHP to log variables
*/
require_once('FirePHPCore/FirePHP.class.php');
ob_start();
$firephp = FirePHP::getInstance(true);

$offerID = $_POST['id'];


$firephp->log($offerID, 'offerID');//For debugging

$publisherToken = 'My super secret token goes here!';
$cleengApi = new Cleeng_Api();
$cleengApi->setPublisherToken($publisherToken);
$offerDetails = $cleengApi->getRentalOffer($offerID);


$firephp->log($offerDetails, 'offerDetails');//For debugging

echo $offerDetails;
?>

当我尝试这个时,我得到内部服务器错误。我尝试使用echo json_encode($ offerDetails);在最后一个echo语句,然后我没有得到服务器错误。但是,响应似乎只包含JSON对象的最后一个元素。

我需要帮助来了解我需要对getRentalOffer()的API响应做些什么,以便将其作为对$ ajax()请求的正确JSON响应传递。

我希望我的问题有道理。 : - )

编辑:使用print_r insead of echo我得到一个响应文本,但遗憾的是有错误。这是文本,它在我看来好像需要在使用print_r之前正确格式化。

"Cleeng_Entity_RentalOffer Object ( [id:protected] => R875937249_SE [publisherEmail:protected] => martin.xxxxxxxx@xxxxxxx.se [url:protected] => http://xxx.xxxxxx.xx/cleeng_tool [title:protected] => Tjohooo! [description:protected] => En skön rulle om Afrika. [price:protected] => 55 [applicableTaxRate:protected] => 0.21 [period:protected] => 48 [currency:protected] => EUR [socialCommissionRate:protected] => 0 [contentType:protected] => video [contentExternalId:protected] => xxxxxxxxxxx [contentExternalData:protected] => {"platform":"vimeo","dimWidth":"500","dimHeight":"369","hasPreview":false,"previewVideoId":"","backgroundImage":"https://i.vimeocdn.com/video/xxxxxxxxx_960.jpg"} [contentAgeRestriction:protected] => [tags:protected] => Array ( [0] => abo ) [active:protected] => 1 [createdAt:protected] => 1400588711 [updatedAt:protected] => 1400606512 [pending:protected] => [averageRating] => 4 ) "

2 个答案:

答案 0 :(得分:0)

您无法回显数组或对象,请尝试使用

print_r($offerDetails);

var_dump($offerDetails);

答案 1 :(得分:0)

解决。

getRentalOffer()返回的对象包含受json_encode不编码的受保护成员,因为它尊重对象变量中的访问参数。我在这篇文章中找到了一个很好的解决方案:http://smorgasbork.com/component/content/article/34-web/65-json-encoding-private-class-members

它不是一个强大的解决方案,因为它依赖于有一天可能关闭的漏洞,所以要小心。但是根据我的需要,它就足够了。