3

所以我们JMSSerializerBundle在 Symfony2 项目中使用 为我们的客户生成一些 JSON。它正在序列化我们的 Doctrine2 实体并且像魅力一样工作,但有一个例外。所有双精度/十进制值都是生成的 JSON 中的字符串,这会使客户端感到困惑。

我们的序列化实体看起来像这样,我这里只粘贴了相关的属性/getter。

class Offer
{
    [...]

    /**
     * @var double $latitude
     *
     * @ORM\Column(name="latitude", type="decimal", precision=10, scale=7)
     * @Groups("offerlist")
     */
    private $latitude;

    /**
     * @var double $longitude
     *
     * @ORM\Column(name="longitude", type="decimal", precision=10, scale=7)
     * @Groups("offerlist")
     */
    private $longitude;

    [...]

    /**
     * Get latitude
     *
     * @return double
     */
    public function getLatitude()
    {
        return $this->latitude;
    }

    /**
     * Get longitude
     *
     * @return double
     */
    public function getLongitude()
    {
        return $this->longitude;
    }

    [...]
}

纬度/经度值显示在 JSON 中,如下所示:

{
    "latitude" : "5.3452",
    "longitude" : "54.2312"
}

如何摆脱引号,所以它是 JSON 中的数字而不是字符串?这应该很容易,但我在文档或网上找不到关于这个问题的任何内容。希望有人可以在这里帮我一把!

4

2 回答 2

5

您的纬度和经度列使用 Doctrine 的十进制类型,表示为字符串。

如果可以的话,你可以使用 Doctrine 的双重类型:

/**
 * ...
 * @ORM\Column(name="latitude", type="double")
 */
private $latitude;

或使用 JMSSerializerBundle 的@Type注解

/**
 * ...
 * @Serializer\Type("double")
 */
private $latitude;
于 2012-09-27T11:06:56.747 回答
0

不要使用“double”作为列类型,因为您可能会遇到坐标表示格式错误的风险。更好地投射你的属性:

     /**
     * Get latitude
     *
     * @return double
     */
    public function getLatitude()
    {
        return (double)$this->latitude;
    }

于 2017-09-04T08:27:37.377 回答