Javascript PHP JSON编码中的JSON格式无效
我有一个对Json数据进行编码的PHP文件,当我查看Json输出时(当它是单个数据块时),我会得到一个有效的Json代码语法,这是一个示例: 但是,当JSON导致多个数据块时,它会生成一个无效的JSON格式,如下所示: 这是我的PHP代码:Javascript PHP JSON编码中的JSON格式无效,javascript,php,mysql,json,jsonp,Javascript,Php,Mysql,Json,Jsonp,我有一个对Json数据进行编码的PHP文件,当我查看Json输出时(当它是单个数据块时),我会得到一个有效的Json代码语法,这是一个示例: 但是,当JSON导致多个数据块时,它会生成一个无效的JSON格式,如下所示: 这是我的PHP代码: <?php header('Content-Type: application/json; charset=utf-8', true,200); DEFINE('DATABASE_USER', 'xxxxx'); DEFINE('DATABASE_
<?php
header('Content-Type: application/json; charset=utf-8', true,200);
DEFINE('DATABASE_USER', 'xxxxx');
DEFINE('DATABASE_PASSWORD', 'xxxxxx');
DEFINE('DATABASE_HOST', 'xxxxxxxxxxx');
DEFINE('DATABASE_NAME', 'xxxxxxxx');
// Make the connection:
$dbc = @mysqli_connect(DATABASE_HOST, DATABASE_USER, DATABASE_PASSWORD,
DATABASE_NAME);
$dbc->set_charset("utf8");
if (!$dbc) {
trigger_error('Could not connect to MySQL: ' . mysqli_connect_error());
}
if(isset($_GET['keyword'])){//IF the url contains the parameter "keyword"
$keyword = trim($_GET['keyword']) ;//Remove any extra space
$keyword = mysqli_real_escape_string($dbc, $keyword);//Some validation
$query = "select name,franco,alpha,id,url,songkey,chord from song where name like '%$keyword%' or franco like '%$keyword%'";
//The SQL Query that will search for the word typed by the user .
$result = mysqli_query($dbc,$query);//Run the Query
if($result){//If query successfull
if(mysqli_affected_rows($dbc)!=0){//and if at least one record is found
while($row = mysqli_fetch_array($result,MYSQLI_ASSOC)){ //Display the record
$data = array();
$data = $row;
echo $_GET[$callback]. ''.json_encode($data).'';
}
}else {
echo 'No Results for :"'.$_GET['keyword'].'"';//No Match found in the Database
}
}
}else {
echo 'Parameter Missing in the URL';//If URL is invalid
}
?>
这是因为您当时正在对结果集的一行进行JSON编码。如果调用客户机需要这样的JSON结构,则这不是有效的JSON结构 很可能,您希望将每一行作为数组中的一个条目,然后对结果数组进行JSON编码和回显 像这样:
if($result){//If query successfull
if(mysqli_affected_rows($dbc)!=0){//and if at least one record is found
$array = array();
while($row = mysqli_fetch_array($result,MYSQLI_ASSOC)){ //Display the record
$array[] = $row;
}
echo json_encode($array);
}
}
谢谢你,迈克,这解决了我的问题。非常感谢你,伙计