2

有没有办法将 Azure 表存储实体转换为 JSON?

PHP 中的 Azure Entity 对象有很多元数据。有没有一种清理它的好方法,并返回一个仅包含相关数据的 JSON 对象。

实体对象打印出类似这样的内容

WindowsAzure\Table\Models\Entity Object
        (
            [_etag:WindowsAzure\Table\Models\Entity:private] => W/"datetime'2013-10-07T04%3A19%3A37.0155205Z'"
            [_properties:WindowsAzure\Table\Models\Entity:private] => Array
                (
                    [PartitionKey] => WindowsAzure\Table\Models\Property Object
                        (
                            [_edmType:WindowsAzure\Table\Models\Property:private] => 
                            [_value:WindowsAzure\Table\Models\Property:private] => weather
                        )

                    [RowKey] => WindowsAzure\Table\Models\Property Object
                        (
                            [_edmType:WindowsAzure\Table\Models\Property:private] => 
                            [_value:WindowsAzure\Table\Models\Property:private] => 0d625293-ef40-492b-bf07-d2889597a8f4
                        )

                    [Timestamp] => WindowsAzure\Table\Models\Property Object
                        (
                            [_edmType:WindowsAzure\Table\Models\Property:private] => Edm.DateTime
                            [_value:WindowsAzure\Table\Models\Property:private] => DateTime Object
                                (
                                    [date] => 2013-10-07 04:19:37
                                    [timezone_type] => 3
                                    [timezone] => UTC
                                )

                        )

                    [type] => WindowsAzure\Table\Models\Property Object
                        (
                            [_edmType:WindowsAzure\Table\Models\Property:private] => Edm.Int32
                            [_value:WindowsAzure\Table\Models\Property:private] => 1
                        )

                    [city] => WindowsAzure\Table\Models\Property Object
                        (
                            [_edmType:WindowsAzure\Table\Models\Property:private] => 
                            [_value:WindowsAzure\Table\Models\Property:private] => Pune
                        )


                    [temperature] => WindowsAzure\Table\Models\Property Object
                        (
                            [_edmType:WindowsAzure\Table\Models\Property:private] => Edm.Int32
                            [_value:WindowsAzure\Table\Models\Property:private] => 34.7
                        )

                    [localTime] => WindowsAzure\Table\Models\Property Object
                        (
                            [_edmType:WindowsAzure\Table\Models\Property:private] => 
                            [_value:WindowsAzure\Table\Models\Property:private] => 2013-10-07T04:19:31.724Z
                        )

                )

        )

我想要一个像这样的干净的 JSON 输出

{
   PartitionKey:"weather",
   RowKey: "0d625293-ef40-492b-bf07-d2889597a8f4",
   Timestamp: "2013-10-07 04:19:37"
   type: 1,
   city: "Pune",
   tempterature: 34.7
   localTime: "2013-10-07T04:19:31.724Z"
}

我已经实现了一个循环来实现这一点。我不确定这是否是最好的方法。

$entities = $result->getEntities();
        $jsonArray = array();

        for ($i = 0; $i < count($entities); $i++) {
            $arr = $entities[$i]->getProperties();
            $tempArr = array();
            foreach ($arr as $key => $value) {
                if(gettype($entities[$i]->getPropertyValue($key)) != 'object'){

                    $tempArr[$key] = (string)$entities[$i]->getPropertyValue($key);                 }
                else
                {

                    $tempArr[$key] = serialize($entities[$i]->getPropertyValue($key));
                }
            }
            array_push($jsonArray, $tempArr);
        }
        echo json_encode($jsonArray);
4

2 回答 2

3

现在 Windows Azure 表存储服务支持 JSON,您可以更轻松地做到这一点。您可以在此处查看公告:Windows Azure 存储版本 - 介绍 CORS、JSON、分钟指标等。

我有一个简单的例子来说明一个类似的场景:http: //www.contentmaster.com/azure/windows-azure-table-storage-json/

该示例显示如何使用客户端 JavaScript 直接从 Windows Azure 表上传和下载。

于 2013-12-12T12:16:39.303 回答
0

我想你已经回答了你自己的问题:)。我会推荐相同的方法,即遍历属性数组并从中创建一个 JSON 表示。

我想提一提的一点是,目前 Windows Azure Tables 不原生支持 JSON,但它很快就会推出(在 7 月的 //Build 会议中演示过)。发生这种情况时,您可以直接请求表存储以 JSON 格式返回数据,而无需进行此转换练习。在那之前,我认为这将是您需要遵循的方法。

于 2013-10-08T04:23:23.203 回答