php - json_encode 在 arrayObject 和 array() 上表现不同

标签 php json geojson

我在 php 中有一个函数:

//simple method with array()
$sensors = array();
$query = "select id, x(transform(wkb_geometry,". $epsg . ")) as lon, y(transform(wkb_geometry,". $epsg . ")) as lat from mytable;";
$result = pg_query($query) or die('Query failed: ' . pg_last_error());
while ($row = pg_fetch_assoc($result)) {
    //var_dump($row);
    $mySensor = new sensor($row['id'],$row['lat'],$row['lon']);
    $sensors[] = $mySensor->geoJSON();
}

echo json_encode($sensors);

输出:

"features": [{
    "type": "Feature",
    "id": 1579028,
    "x": 4.85310557823,
    "y": 52.7205622103,
    "geometry": {
      "type": "Point",
      "coordinates": [4.85310557823, 52.7205622103],
      "crs": {
        "type": "OGC",
        "properties": {
          "urn": "urn:ogc:def:crs:OGC:1.3:CRS84"
        }
      }

现在我重写了数组,变成了这样的对象:

//advanced method with arrayObject:
class sensors extends ArrayObject {
    function __construct($epsg){
        $query = "select id, x(transform(wkb_geometry,". $epsg . ")) as lon, y(transform(wkb_geometry,". $epsg . ")) as lat from mytable;";
        $result = pg_query($query) or die('Query failed: ' . pg_last_error());
        while ($row = pg_fetch_assoc($result)) {
            //var_dump($row);
            $mySensor = new sensor($row['id'],$row['lat'],$row['lon']);
                $this[] = $mySensor->geoJSON();
            }
        }
    }
}
$newsensors = new sensors($epsg);
echo echo json_encode($newsensors);

但这会将输出更改为:

"features": {
  "0": {
    "type": "Feature",
    "id": 1579028,
    "x": 4.85310557823,
    "y": 52.7205622103,
    "geometry": {
      "type": "Point",
      "coordinates": [4.85310557823, 52.7205622103],
      "crs": {
        "type": "OGC",
        "properties": {
          "urn": "urn:ogc:def:crs:OGC:1.3:CRS84"
        }
      }
    }
  },

这使得它不能用作 OpenLayers 的 geoJSON。为什么 json_encode 函数会这样?我可以关闭索引号的设置吗?这可能是一个小错误吗?

最佳答案

json_encode 将对任何对象显示相同的行为,即使是像 ArrayObject 那样实现了 ArrayAccess 接口(interface)的对象;使用公共(public)属性。

要获得您想要的行为,您应该将一个实际数组传递给它,该数组可以通过调用 ArrayObject::getArrayCopy() 检索(或者您可以将对象转换为数组)。

echo json_encode($newsensors->getArrayCopy());

关于php - json_encode 在 arrayObject 和 array() 上表现不同,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2716535/

相关文章:

php - 在 PHP 中的 mysqli 准备语句中使用 REGEXP

javascript - 通过 CSS 和 javascript 绘制树和动态设计(模式)

javascript - 如何防止错误 : "Window navigated away"

javascript - 如何在传单中设置 geoJSON FeatureCollection 的样式?

php - 如何使用 PHP 和 SQL 在一个文本框中搜索特定项目?

php - 连接android与php和mysql

php - 使用 session 处理程序时出现交替类未找到错误

javascript - 我如何从 react 中的 Json 对象中读取单个元素?

javascript - 在实际需要时点击填写传单弹出窗口

javascript - Leaflet foreach功能自动触发鼠标悬停功能