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