首页 > 解决方案 > PHP JSON API - 检测返回值的数据类型

问题描述

我正在研究一个PHP JSON API返回json_encoded多维数组的方法。由于事实上,这PHP是一种弱类型语言 - 我在客户端返回的数据类型存在一些问题,例如整数作为字符串返回。

响应示例

json 编码前

array() {
  ["users"]=>
  array() {
    ["id"]=>
    string(3) "983"
    ["email"]=>
    string(28) "xxx.xxx@xxx.xxx"
    ["username"]=>
    string(8) "xxx"
    ["verified"]=>
    string(1) "2"
    ["tutorial_completed"]=>
    string(1) "1"
  }
  ["companies"]=>
  array() {
    ["id"]=>
    string(3) "170"
    ["name"]=>
    string(0) "xxx"
    ["trusted"]=>
    string(1) "1"
  }
}

json编码后

data: {
   users: {
     id: "983",
     email: "xxx@xxx.xxx",
     username: "xxx",
     verified: "2",
     tutorial_completed: "1",
   },
   companies: {
     id: "170",
     name: "xxx",    
     trusted: "1",
   }
}

我正在从MySQL table. 这些值基本上是按原样取的。

一种可行的解决方案intval()是检查每个键,然后通过or转换数值floatval()- 但这意味着要为更大的数组付出巨大的努力,并且该解决方案缺乏灵活性。

它们是否是一种自动检测数据类型是否也可以是数值的平滑方法,如果可以,则进行转换?

标签: phpjsoncasting

解决方案


问题:当您从 PHP 中从 MySQL 数据库中获取数据时,无论数据库中的字段是什么类型,结果中的字段都是字符串类型或 NULL。这与MYSQL驱动程序有关。

解决方案:您需要自己将数值转换为数组中所需的类型。或者,当您转换为 json 时,您可以简单地使用:

$encoded = json_encode($data, JSON_NUMERIC_CHECK);

数字字段将自动为您转换。


推荐阅读