我使用了var_dump
但我需要json类型。
我的网站托管是5.2 php版本,因此无法使用
print(json_encode($ json_output,JSON_UNESCAPED_UNICODE));
while($row=mysqli_fetch_assoc($query)) {
$json_output[]=$row;
}
print(json_encode($json_output));
吼叫是破碎的角色
[
{
"name":"chulhoon",
"description":"\ud558\ud558\ud638\ud638",
"dob":"\uc548\ub155\ud558\uc138\uc694",
"county":"\ub9cc\ub098\uc11c",
"height":"\ubc18\uac00\uc6cc\uc694",
"spouse":"\ubb50\ub4e4\ud558\uc138\uc694",
"children":"\uc774\ubbf8\uc9c0\uc55e\uc790\ub9ac",
"image":"http:\/\/microblogging.wingnity.com\/JSONParsingTutorial\/johnny.jpg"
}
]
答案 0 :(得分:2)
这没有打破。这些奇怪的序列是unicode字符。您可以尝试使用
print(json_encode($json_output, JSON_UNESCAPED_UNICODE));
相反,如果你是PHP> = 5.4。这应该保持unicode字符的原始形式。但是,在存储或传输JSON字符串时,这可能会导致一些其他问题。
答案 1 :(得分:0)
function json_encode2($data) {
switch (gettype($data)) {
case 'boolean':
return $data?'true':'false';
case 'integer':
case 'double':
return $data;
case 'string':
return '"'.strtr($data, array('\\'=>'\\\\','"'=>'\\"')).'"';
case 'array':
$rel = false; // relative array?
$key = array_keys($data);
foreach ($key as $v) {
if (!is_int($v)) {
$rel = true;
break;
}
}
$arr = array();
foreach ($data as $k=>$v) {
$arr[] = ($rel?'"'.strtr($k,array('\\'=>'\\\\','"'=>'\\"')).'":':'').json_encode2($v);
}
return $rel?'{'.join(',', $arr).'}':'['.join(',', $arr).']';
default:
return '""';
}
}
这很酷! 谢谢大家。
echo json_encode2($ data);
{“test”:“test data”,“sample”:“sample string”,“data2”:[0,1,2,3,{“beskin”:“31”}],“bool”:真, “number_data”:33282, “PI”:3.14}