PHP获取数据库中数据生成json, 中文乱码问题的解决方案
1.在代码前段写上
header("Content-Type: text/html;charset=utf8");
2.在connection建立以后写上
mysqli_query($connection, "SET NAMES utf8");
————至此就可以在PHP页面中显示中文了————-
最后, 如果需要用到json_encode, 那么需要注意最后一点
$json_string = json_encode($result_row, JSON_UNESCAPED_UNICODE); //php5.4以上
即在普通的json_encode中多加入一个参数, 至此就全部完成啦~
让json更懂中文(JSON_UNESCAPED_UNICODE)
<?php
echo json_encode("中文", JSON_UNESCAPED_UNICODE); //需要5.4以上版本才能支持 unescaped_unicode: unicode转义
$data = array(
0=>array('status'=>'1', 'method'=>'登陆', 'message'=>'成功',"url"=>"http://q.qlogo.cn/qqapp/1105737075/788B369AB26335DDDFB5E45199B95FDD/40"),
1=>array('status'=>'2', 'method'=>'注销', 'message'=>'成功',"url"=>"http://q.qlogo.cn/qqapp/1105737075/788B369AB26335DDDFB5E45199B95FDD/41"),
);
echo json_encode($data, JSON_UNESCAPED_UNICODE);
输出结果:
[{"status":"1","method":"登陆","message":"成功","url":"http:\/\/q.qlogo.cn\/qqapp\/1105737075\/788B369AB26335DDDFB5E45199B95FDD\/40"},{"status":"2","method":"注销","message":"成功","url":"http:\/\/q.qlogo.cn\/qqapp\/1105737075\/788B369AB26335DDDFB5E45199B95FDD\/41"}]
注意: 这个参数只解决中文转码问题, url地址自动加上转义字符, 并未解决。
PHP5.4以上才支持JSON_UNESCAPED_UNICODE这个参数, 此参数是让中文字符在json_encode的时候不用转义, 减少数据传输量。但在PHP5.3中, 就得自己写个函数来实现, 以下就是解决方法:
/**
* 对变量进行 JSON 编码
* @param mixed value 待编码的 value ,除了resource 类型之外,可以为任何数据类型,该函数只能接受 UTF-8 编码的数据
* @return string 返回 value 值的 JSON 形式
*/
function json_encode_ex($value)
{
if (version_compare(PHP_VERSION,'5.4.0','<')){
$str = json_encode($value);
$str = preg_replace_callback("#\\\u([0-9a-f]{4})#i",
function($matchs){
return iconv('UCS-2BE', 'UTF-8', pack('H4', $matchs[1]));
},
$str
);
return $str;
}else{
return json_encode($value, JSON_UNESCAPED_UNICODE);
}
}
//使用方法
$data = array(
0=>array('status'=>'1', 'method'=>'登陆', 'message'=>'成功',"url"=>"http://q.qlogo.cn/qqapp/1105737075/788B369AB26335DDDFB5E45199B95FDD/40"),
1=>array('status'=>'2', 'method'=>'注销', 'message'=>'成功',"url"=>"http://q.qlogo.cn/qqapp/1105737075/788B369AB26335DDDFB5E45199B95FDD/41"),
);
echo json_encode_ex($data); //这个函数只解决中文转码问题, url地址自动加上转义字符, 并未解决
?>
输出结果:
[{"status":"1","method":"登陆","message":"成功","url":"http:\/\/q.qlogo.cn\/qqapp\/1105737075\/788B369AB26335DDDFB5E45199B95FDD\/40"},{"status":"2","method":"注销","message":"成功","url":"http:\/\/q.qlogo.cn\/qqapp\/1105737075\/788B369AB26335DDDFB5E45199B95FDD\/41"}]
本文暂时没有评论,来添加一个吧(●'◡'●)