PHP传给app的JSON有什么要求?
我从数据库取出数据后发到web上,让APP去获取信息:
$result = mysql_query("select * from his");
while ($arr = mysql_fetch_assoc($result)) {
$json = json_encode($arr,JSON_UNESCAPED_UNICODE);
echo $json;
}
输出到界面的json为:
{"hps_userid":"1","hps_userid2":"1"}
现在app端无法获取数据是我的输出格式问题还是app那边的问题?
现在app那边的同事说需要这种格式才可以
{"No.":[{"hps_userid":"1","hps_userid2":"1"}]}
当搜索到多条数据的时候,又要怎么如何输出?
Khoomei
9 years, 6 months ago
Answers
“现在app那边的同事说需要这种格式才可以”,“才可以”,哈哈。。。
以前我和别人合作的时候也听到过类似的说法,然而后来我学了安卓开发。。。
妈蛋的,才发现,明明是他们解析JSON的代码不怎么会写,还怪我给的格式不对。。。
只要输出的是标准的JSON格式,信息完整,组织正确,根本不存在解析不了的问题。
{"No.":[{"hps_userid":"1","hps_userid2":"1"}]}
这个"No"的存在并没有什么必要(只是因为他们JSON解析不太会)。
话说,“当搜索到多条数据的时候,又要怎么如何输出?"
这种问题应该一开始就考虑好,好吧?
[
{
"hps_userid": "1",
"hps_userid2": "1"
},
{
"hps_userid": "2",
"hps_userid2": "3"
},
{
"hps_userid": "4",
"hps_userid2": "5"
}
]
取多条数据,最后都保存到一个数组里,然后把数组转成JSON,就是上面这样的了。
话说你的代码怎么会是这样。。。
$result = mysql_query("select * from his");
while ($arr = mysql_fetch_assoc($result)) {
$json = json_encode($arr,JSON_UNESCAPED_UNICODE);
echo $json;
}
你知道while循环了几次吗?每次循环都echo,最后输出的是类似这样的:
{"hps_userid":"1","hps_userid2":"1"}{"hps_userid":"1","hps_userid2":"1"}{"hps_userid":"1","hps_userid2":"1"}{"hps_userid":"1","hps_userid2":"1"}{"hps_userid":"1","hps_userid2":"1"}{"hps_userid":"1","hps_userid2":"1"}
这种连起来的就根本不是JSON字符串啊。。。
。。。。。。
如下:
$result = mysql_query("select * from his");
$Temp = array();
$row = mysql_fetch_assoc($result);
while ($row) {
$Temp[] = array("hps_userid"=>$row["hps_userid"],"hps_userid2"=>$row["hps_userid2"]);
$row = mysql_fetch_assoc($result);
}
die(json_encode($Temp));
//或者你就听你们那个逗比APP工程师的:
//die(json_encode(array("No."=>$Temp)));
johniff
answered 9 years, 6 months ago