国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > PHP > 正文

php json_encode實現與中文亂碼解決方法

2024-05-04 21:57:58
字體:
來源:轉載
供稿:網友

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).'})'

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 玉山县| 宣武区| 清涧县| 上林县| 沁阳市| 水富县| 临西县| 开化县| 和龙市| 炎陵县| 湛江市| 敦煌市| 忻城县| 壤塘县| 肇庆市| 赞皇县| 咸宁市| 托克托县| 尉氏县| 惠东县| 岳阳县| 监利县| 抚顺县| 鱼台县| 吉隆县| 宁陵县| 改则县| 石渠县| 贺州市| 团风县| 诸暨市| 平湖市| 五大连池市| 确山县| 陈巴尔虎旗| 阜平县| 海安县| 西平县| 浙江省| 尚义县| 时尚|