程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> php5.2 Json不能正確處理中文、GB編碼的解決方法

php5.2 Json不能正確處理中文、GB編碼的解決方法

編輯:關於PHP編程

     json_encode對中文的處理是有問題,不能處理GB編碼,所有的GB編碼都會替換成空字符,下面有個不錯的解決方法,大家可以參考下

    php5.2新增的json功能是非常受歡迎的,但是經過測試發現,  json_encode對中文的處理是有問題的,  1.不能處理GB編碼,所有的GB編碼都會替換成空字符.  2.utf8編碼的中文被編碼成unicode編碼,相當於javascript的escape函數處理的結果.  代碼如下: /*    為了能正確使用json,首先我們就應該在編碼上采用utf8編碼,然後再對json_encode的返回結果稍加處理就可以得到正確的結果了。  我寫了一個簡單的類,將這兩個函數包裝了一下,  **/  class Json{  public static function encode($str){  $code = json_encode($str);  return preg_replace("#u([0-9a-f]+)#ie", "iconv('UCS-2', 'UTF-8', pack('H4', '1'))", $code);  }    public static function decode($str){  return json_decode($str);  }  }  //使用的時候    Json::encode($code);  Json::decode($code);  /**這樣可以正確處理utf8編碼的中文了。    PS:對於GB編碼的中文,我們可以在編碼時先轉成UTF8編碼,再進行編碼,解碼的時候再進行一個utf8 -> gb的轉換就可以了。  另外一般json_encode的結果我們是返回到客戶端來使用,我們其實還可以用javascript的unescape函數來對unicode編碼的中文進行解碼,從而還原成正確的中文。    或者用:$title = mb_convert_encoding($title, 'HTML-ENTITIES', $this->_outCharset);//任意編碼下都正常顯示  ********/   
    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved