0

I need to grab some json code; it is starting with [

If I try to loop it, I retrieve

Warning: Invalid argument supplied for foreach()

Can someone help me to decode properly this json? thanks

PHP Code:

echo "<h2>Tradedoubler Coupon</h2>";
$tdjson = file_get_contents("http://api.tradedoubler.com/1.0/vouchers.json;voucherTypeId=1?token=280C407EC3D32D2C8E4C04A100DD00FEA9000580");
//$tdobj = json_decode(print_r($tdjson));
$tdobj = json_decode($tdjson,true);
//foreach($tdobj as $prog ) {
echo '<ul>';
echo '<li>' . print_r($tdobj) . '</li>
</ul>';

JSON file:

[
    {
        id: 20108,
        programId: 17269,
        programName: "",
        code: "6G4KGGDH",
        updateDate: "1369813973159",
        publishStartDate: "1370037600000",
        publishEndDate: "1372629599999",
        startDate: "1370037600000",
        endDate: "1372629599999",
        title: "Sconto",
        shortDescription: "kkkkk",
        description: "kkkk",
        voucherTypeId: 1,
        defaultTrackUri: "http://url.com/click?a(1556954)p(17269)ttid(13)",
        siteSpecific: false,
        discountAmount: 5,
        isPercentage: false,
        publisherInformation: "",
        languageId: "it",
        exclusive: false,
        currencyId: "EUR",
        logoPath: "http://url.com/file/17269/eDreams_100x50.jpg"
    },
    {
        id: 19699,
        programId: 29519,
            programName: "",
        code: "6G4KGGDH",
        updateDate: "1369813973159",
        publishStartDate: "1370037600000",
        publishEndDate: "1372629599999",
        startDate: "1370037600000",
        endDate: "1372629599999",
        title: "Sconto",
        shortDescription: "kkkkk",
        description: "kkkk",
        voucherTypeId: 1,
        defaultTrackUri: "http://url.com/click?a(1556954)p(17269)ttid(13)",
        siteSpecific: false,
        discountAmount: 5,
        isPercentage: false,
        publisherInformation: "",
        languageId: "it",
        exclusive: false,
        currencyId: "EUR",
        logoPath: "http://url.com/file/17269/eDreams_100x50.jpg"
    }
]
4

2 に答える 2

1

Tradedoubler からの JSON が無効です。問題は、オブジェクトのプロパティ名を二重引用符で囲んでおらず、値だけを囲んでいることです。

たとえば、次のようにします。

$json = '[
    {
        "id": 20108,
        "programId": 17269,
        "programName": "",
        "code": "6G4KGGDH"
    },
    {
        "id": 19699,
        "programId": 29519,
        "programName": "",
        "code": "6G4KGGDH"
    }
]';

print_r(json_decode($json));

上記の JSON では、必要な二重引用符を追加しました。そのコードを実行すると、正常に出力されることがわかります。

Array
(
    [0] => stdClass Object
        (
            [id] => 20108
            [programId] => 17269
            [programName] => 
            [code] => 6G4KGGDH
        )

    [1] => stdClass Object
        (
            [id] => 19699
            [programId] => 29519
            [programName] => 
            [code] => 6G4KGGDH
        )

)

したがって、次の 2 つのオプションがあります。

  1. Tradedoubler に連絡して、有効な JSON を提供するように依頼します
  2. 引用符が欠落しているプロパティ名を解析して挿入します。これにより、元の無効な JSON が修正されます。

JSON のスニペットが有効かどうかをテストする場合は、それをjsonlint.comに貼り付けると、エラーの場所がわかります。tradedoubler から JSON を貼り付けると、実際には無効であることがわかります。

于 2013-06-03T11:49:28.503 に答える
0

最後に解決策があります。Tradedoubler はバウチャー ファイルの xml バージョンも提供するため、curl を使用してデコードできます。

    <?php

$url="http://api.tradedoubler.com/1.0/vouchers?token=YOURTOKEN";
$ch = curl_init();
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_URL, $url);    // get the url contents

$data = curl_exec($ch); // execute curl request
curl_close($ch);

$xml = simplexml_load_string($data);
print_r($xml);

?>

結果をループするには:

<?php

$url="http://api.tradedoubler.com/1.0/vouchers?token=YOUR TOKEN HERE";
$ch = curl_init();
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_URL, $url);    // get the url contents

$data = curl_exec($ch); // execute curl request
curl_close($ch);

$xml = simplexml_load_string($data);
foreach ($xml->voucher as $coupon){
echo '<li>'.$coupon->id.' - '.$coupon->programId.' - '.$coupon->programName.' - '.$coupon->code.' - '.$coupon->title.' - '.$coupon->shortDescription.' - '.$coupon->description.'</li>';
}

?> 
于 2014-04-19T13:53:33.267 に答える