程序员人生 网站导航

php json_encode实现与中文乱码解决方法

栏目:php教程时间:2014-05-06 06:33:14

php 中使用 json_encode() 内置函数(php > 5.2)可以使用得 php 中数据可以与其它语言很好的传递并且使用它,这个函数的功能是将数值转换成json数据存储格式.

  1. $arr = array ('a'=>1,'b'=>2,'c'=>3,'d'=>4,'e'=>5); 
  2. echo json_encode($arr); 
  3. //结果 
  4. //{"a":1,"b":2,"c":3,"d":4,"e":5} 

下面看一款json_encode中文乱码问题:

解决方法是用urlencode()函数处理以下,在json_encode之前,把所有数组内所有内容都用urlencode()处理一下,然用json_encode()转换成json字符串,最后再用urldecode()将编码过的中文转回来.

  1. function arrayrecursive(&$array$function$apply_to_keys_also = false) 
  2.     static $recursive_counter = 0; 
  3.     if (++$recursive_counter > 1000) { 
  4.         die('possible deep recursion attack'); 
  5.     } 
  6.     foreach ($array as $key => $value) { 
  7.         if (is_array($value)) { 
  8.             arrayrecursive($array[$key], $function$apply_to_keys_also); 
  9.         } else { 
  10.             $array[$key] = $function($value); 
  11.         } 
  12.  
  13.         if ($apply_to_keys_also && is_string($key)) { 
  14.             $new_key = $function($key); 
  15.             if ($new_key != $key) { 
  16.                 $array[$new_key] = $array[$key]; 
  17.                 unset($array[$key]); 
  18.             } 
  19.         } 
  20.     } 
  21.     $recursive_counter--; 
  22.  
  23. /************************************************************** 
  24.  * 
  25.  * 将数组转换为json字符串(兼容中文) 
  26.  * @param array $array  要转换的数组 
  27.  * @return string  转换得到的json字符串 
  28.  * @access public 
  29.  * 
  30.  *************************************************************/ 
  31. function json($array) { 
  32.  arrayrecursive($array'urlencode', true); 
  33.  $json = json_encode($array); 
  34.  return urldecode($json); 
  35. $array = array 
  36.        ( 
  37.           'name'=>'希亚'
  38.           'age'=>20 
  39.        ); 
  40. echo json($array); 

应用实例:

  1. $servname="localhost"
  2. $sqlservname="root"
  3. $sqlservpws="123456"
  4. $sqlname="lock1"
  5. $db=mysql_connect($servname,$sqlservname,$sqlservpwsor die("数据库连接失败"); 
  6. mysql_select_db($sqlname,$db); 
  7. $sql = "select * from t_operater"
  8. $result =mysql_query($sql); 
  9. $rows = mysql_num_rows($result); 
  10. while($obj = mysql_fetch_object($result)) 
  11. $arr[] = $obj
  12. echo '({"total":"'.$rows.'","results":'.json_encode($arr).'})'
------分隔线----------------------------
------分隔线----------------------------

最新技术推荐