编程语言
首页 > 编程语言> > php – Silex – app-> json()将整数数据作为字符串返回

php – Silex – app-> json()将整数数据作为字符串返回

作者:互联网

我刚开始与Silex合作,帮助我构建一个从MySQL数据库返回数据的restful api.以前在使用php和mysql时,我注意到MySQL会将整数作为字符串返回到json_encode()函数中.它会在我的所有整数值周围加上引号.我能够解决这个问题的唯一方法是将JSON_NUMERIC_CHECK传递给json_encode函数:

return json_encode($array, JSON_NUMERIC_CHECK);

为我需要的东西工作可爱.现在我正在使用silex我一直在使用它的内置json函数来从我的控制器返回值.我注意到我遇到的问题是整数被返回为带有引号的字符串.

$app->get('/suppliers', function () use ($app) {
    $sql = "SELECT * FROM suppliers";
    $suppliers = $app['db']->fetchAll($sql);

    return $app->json(array('suppliers' => $suppliers));
});

供应商有一个整数的supplier_id字段,但它在json数据中以字符串形式返回.我尝试在我的数组之后将JSON_NUMERIC_CHECK传递到$app-> json()函数,但是会得到InvalidArguementException.

我确实弄清楚而不是使用$app-> json()函数我可以使用json_encode()php函数,它会工作.像这样:

$app->get('/suppliers', function () use ($app) {
    $sql = "SELECT * FROM suppliers";
    $suppliers = $app['db']->fetchAll($sql);

    //return $app->json(array('suppliers' => $suppliers));
    return json_encode(array('suppliers' => $suppliers), JSON_NUMERIC_CHECK);
});

有没有理由不这样做而不是使用silex $app-> json()函数?有没有更好的方法呢?

解决方法:

$app-> json(…)返回响应JsonResponse.您可以手动创建此类响应并设置编码选项.

$app->get('/suppliers', function () use ($app) {
    $sql = "SELECT * FROM suppliers";
    $suppliers = $app['db']->fetchAll($sql);

    $response = new \Symfony\Component\HttpFoundation\JsonResponse();
    $response->setEncodingOptions(JSON_NUMERIC_CHECK);
    $response->setData(array('suppliers' => $suppliers));

    return $response;
});

或设置allready编码的内容

$app->get('/suppliers', function () use ($app) {
    $sql = "SELECT * FROM suppliers";
    $suppliers = $app['db']->fetchAll($sql);

    $response = new \Symfony\Component\HttpFoundation\JsonResponse();
    $response->setContent(json_encode(array('suppliers' => $suppliers), JSON_NUMERIC_CHECK));

    return $response;
});

标签:json,php,mysql,silex
来源: https://codeday.me/bug/20190713/1449242.html