用PHP的json_encode来处理中文的时候, 中文都会被编码, 变成不可读的, 类似”\u***”的格式,如果想汉字不进行转码,这里提供2种方法
1.升级PHP,使用PHP5.4以上版本 这个问题终于得以解决, Json新增了一个选项: JSON_UNESCAPED_UNICODE, 故名思议, 就是说, Json不要编码Unicode.
2.当PHP5.4版本以下,代码如下
class ServerClass{
/**************************************************************
*
* 使用特定function对数组中所有元素做处理
* @param string &$array 要处理的字符串
* @param string $function 要执行的函数
* @return boolean $apply_to_keys_also 是否也应用到key上
* @access public
*
*************************************************************/
Public function arrayRecursive(&$array, $function, $apply_to_keys_also = false)
{
static $recursive_counter = 0;
if (++$recursive_counter > 1000) {
die('possible deep recursion attack');
}
foreach ($array as $key => $value) {
if (is_array($value)) {
self::arrayRecursive($array[$key], $function, $apply_to_keys_also);
} else {
$array[$key] = $function($value);
}
if ($apply_to_keys_also && is_string($key)) {
$new_key = $function($key);
if ($new_key != $key) {
$array[$new_key] = $array[$key];
unset($array[$key]);
}
}
}
$recursive_counter--;
}
/**************************************************************
*
* 将数组转换为JSON字符串(兼容中文)
* @param array $array 要转换的数组
* @return string 转换得到的json字符串
* @access public
*
*************************************************************/
Public function JSON($array) {
self::arrayRecursive($array, 'urlencode', true);//内部函数互调用self::
$json = json_encode($array);
return urldecode($json);
}
Public Function Search() {
$Conn=Mysqli_connect("localhost","a1022185526","90744321","a1022185526");//主机,用户,密码,数据库
If(!$Conn) {
Die("连接数据库失败".mysqli_connect_error($Conn));
}
Mysqli_query($Conn,"set names utf8");
$Result=Mysqli_query($Conn,"Select * From Ruyiweb_user");
While($Row = Mysqli_fetch_assoc($Result)){
$Arr[] = $Row;
}
Mysqli_free_result($Result);
//$Json = json_encode($Arr,JSON_UNESCAPED_UNICODE);//PHP5.4以上JSON_UNESCAPED_UNICODE, 故名思议, 就是说, Json不要编码Unicode.
$Json=self::JSON($Arr);
Mysqli_close($Conn);
Return $Json;
}
}
$serverclass1=new ServerClass();
echo $serverclass1->Search();
?>