4

我知道这可能很简单,我开始了解我需要如何去做,我意识到这与 OO 有关,但是因为我是 OO 和 json 的新手,我对这个http有点问题://api.discogs.com/database/search?q=d&page=1&per_page=5它以 json 格式返回 5 个查询结果,d因此我使用 php 函数对其进行解析,然后尝试让第一个显示缩略图结果这是我的解析代码:

$returnData = file_get_contents($queryURL);
$discogsJSON = json_decode($returnData);

其中$queryURL= 提供的网址。如果我打印$discogsJSON我得到这个:

<pre>stdClass Object
(
[pagination] => stdClass Object
    (
        [per_page] => 5
        [items] => 179465
        [page] => 1
        [urls] => stdClass Object
            (
                [last] => http://api.discogs.com/database/search?q=f&per_page=5&page=35893
                [next] => http://api.discogs.com/database/search?q=f&per_page=5&page=2
            )

        [pages] => 35893
    )

[results] => Array
    (
        [0] => stdClass Object
            (
                [style] => Array
                    (
                        [0] => Free Jazz
                    )

                [thumb] => http://api.discogs.com/image/R-90-1672955-1305426452.jpeg
                [format] => Array
                    (
                        [0] => Vinyl
                        [1] => LP
                        [2] => Album
                    )

                [country] => Switzerland
                [title] => Steve Lacy - Clinkers
                [uri] => /Steve-Lacy-Clinkers/master/54331
                [label] => Array
                    (
                        [0] => Hat Hut Records
                    )

                [catno] => F
                [year] => 1978
                [genre] => Array
                    (
                        [0] => Jazz
                    )

                [resource_url] => http://api.discogs.com/masters/54331
                [type] => master
                [id] => 54331
            )

        [1] => stdClass Object
            (
                [style] => Array
                    (
                        [0] => Free Jazz
                    )

                [thumb] => http://api.discogs.com/image/R-90-1672955-1305426452.jpeg
                [format] => Array
                    (
                        [0] => Vinyl
                        [1] => LP
                        [2] => Album
                    )

                [country] => Switzerland
                [title] => Steve Lacy - Clinkers
                [uri] => /Steve-Lacy-Clinkers/release/1672955
                [label] => Array
                    (
                        [0] => Hat Hut Records
                    )

                [catno] => F
                [year] => 1978
                [genre] => Array
                    (
                        [0] => Jazz
                    )

                [resource_url] => http://api.discogs.com/releases/1672955
                [type] => release
                [id] => 1672955
            )

        [2] => stdClass Object
            (
                [style] => Array
                    (
                        [0] => Alternative Rock
                        [1] => Goth Rock
                        [2] => Heavy Metal
                    )

                [thumb] => http://api.discogs.com/image/R-90-2785283-1300918365.jpeg
                [format] => Array
                    (
                        [0] => CD
                        [1] => Compilation
                        [2] => Unofficial Release
                    )

                [country] => Russia
                [title] => HIM (2) - Overload Hits
                [uri] => /HIM-Overload-Hits/release/2785283
                [label] => Array
                    (
                        [0] => FullHouse Records
                    )

                [catno] => F?????
                [year] => 2003
                [genre] => Array
                    (
                        [0] => Rock
                    )

                [resource_url] => http://api.discogs.com/releases/2785283
                [type] => release
                [id] => 2785283
            )

        [3] => stdClass Object
            (
                [style] => Array
                    (
                        [0] => Drone
                        [1] => Ambient
                    )

                [thumb] => http://api.discogs.com/image/R-90-3108621-1316178067.jpeg
                [format] => Array
                    (
                        [0] => CDr
                        [1] => Album
                        [2] => Limited Edition
                    )

                [country] => Russia
                [title] => Solar Ocean - Twillight October
                [uri] => /Solar-Ocean-Twillight-October/release/3108621
                [label] => Array
                    (
                        [0] => Necrophone
                    )

                [catno] => F
                [year] => 2010
                [genre] => Array
                    (
                        [0] => Electronic
                    )

                [resource_url] => http://api.discogs.com/releases/3108621
                [type] => release
                [id] => 3108621
            )

        [4] => stdClass Object
            (
                [style] => Array
                    (
                        [0] => Techno
                        [1] => Electro
                        [2] => Tech House
                        [3] => Minimal
                    )

                [thumb] => http://api.discogs.com/image/R-90-699054-1161976299.jpeg
                [format] => Array
                    (
                        [0] => Vinyl
                        [1] => 12"
                        [2] => Box Set
                        [3] => Compilation
                        [4] => Limited Edition
                    )

                [country] => Germany
                [title] => Various - Cocoon Compilation F
                [uri] => /Various-Cocoon-Compilation-F/master/33655
                [label] => Array
                    (
                        [0] => Cocoon Recordings
                        [1] => Cocoon Compilation
                    )

                [catno] => COR LP 011
                [year] => 2006
                [genre] => Array
                    (
                        [0] => Electronic
                    )

                [resource_url] => http://api.discogs.com/masters/33655
                [type] => master
                [id] => 33655
            )

    )

)
</pre>

这是完全正确的,我可以看到我想要的所有数据,但是当我尝试访问(比如说第一个的缩略图)时,如下所示:

echo $discogsJSON['results']['0']['thumb'];

我剩下:Fatal error: Cannot use object of type stdClass as array

我想从这里有足够的信息来构建正确的 echo 语句,但是任何人都可以向我解释正确获取数据方法背后的 OO 理论吗?

4

2 回答 2

17

$discogsJSON不是数组,而是stdClass对象。results 是这个对象的一个​​属性。

这应该做你正在寻找的。

echo $discogsJSON->results['0']->thumb;

true但是,添加标志以json_decode确保返回的值是关联数组可能更方便。

$discogsJSON = json_decode($returnData, true);
于 2013-07-08T01:42:11.030 回答
1

您需要通过添加true作为 json_decode的第二个参数来使数组具有关联性

$discogsJSON = json_decode($returnData, true);

于 2015-05-07T13:57:05.673 回答