如何从用PHP编写的Web服务输出JSONArray


How to output a JSONArray from a webservice written in PHP

>我有用PHP编写的Web服务,它从本地数据库读取并以JSON输出结果。

但是,我无法将其输出到 JSONArray 中。

这是 php 脚本

<?php
$username = "root";
$password = "";
$hostname = "localhost"; 
$response=array();
//connection to the database
$dbhandle = mysql_connect($hostname, $username, $password) 
or die("Unable to connect to MySQL");
//select a database to work with
$selected = mysql_select_db("test",$dbhandle) 
or die("Could not select test");
//execute the SQL query and return records
$result = mysql_query("SELECT name, country FROM android");
$response["infos"] = array();   
while ($row = mysql_fetch_assoc($result)) {
    $info = array();
$info["name"]=$row["name"];
$info["country"]=$row["country"];
    print(json_encode($info));
}
//close the connection
mysql_close($dbhandle);
?>

这是 Web 服务的输出

{"name":"develop","country":"mru"}{"name":"fufu","country":"tutu"}  {"name":"chikaka","country":"aceVentura"}

但是有人告诉我,这不是在JSONArray中。

我在这里错过了什么?

谢谢

在您的示例中,您要回显出多个 JSON 字符串,因为您的输出代码位于while循环中。JSON 字符串应该只有一个输出。下面的代码将为您提供一个 JSON 格式的二维数组。

$info = array();
while ($row = mysql_fetch_assoc($result)) 
{
     $arr = array();
     $arr["name"] = $row["name"];
     $arr["country"] = $row["country"];
     $info[] = $arr;
}
echo json_encode($info);