我正在使用Android创建一个应用程序。其中用户答案通过PHP代码存储在服务器上的mySQL上。
function fetch_all_complaints_by_packet($packet) {
global $dBConnection;
$query = "SELECT * FROM ".DB_PREFIX ."complaint ORDER BY id DESC LIMIT 0 , 10";
$result = mysql_query($query,$dBConnection) or die('Errant query: '.$query);
$complaints = array();
if(mysql_num_rows($result)) {
$i = 0;
while($complaint = mysql_fetch_assoc($result)) {
$complaints[$i] = $complaint;
echo ($complaint['details'].'<br>');
$i++;
}
}
//echo json_encode($complaints);
}下面这行
echo json_encode();导致错误它将详细信息显示为NULL,但是
echo json_encode($complaint['details'].'<br>');打印正确的数据。问题出在哪里?
发布于 2011-10-06 01:08:53
我有一些类似的东西,如果问题是一样的,可以在你这边检查一下:
当您有一个无效的UTF-8字符串(无效的utf-8字符)并尝试JSON_Encode该数据时,它将返回NULL。
我花了几个小时才在我的代码中找到了这一点,因为毕竟它是AJAX调用,所以您看不到出现的错误。
我的建议是打开错误记录并显示所有错误,您可能会看到有关UTF-8编码失败的错误。如果没有,请尝试utf8_decode您的数据,看看它是否会排除我告诉您的错误。
https://stackoverflow.com/questions/7664542
复制相似问题