本文轉自http://www.111cn.net/phper/31/50680.htm

今天要在MySQL 存儲php中json_encode格式資訊,英文時沒有問題,但是中文時就碰到了遇到中文時, 會變成一堆類似uxxxx資訊.

1. 原因分析:

在存儲到資料庫時!MySQL 不會存儲 unicode 字元:

MySQL 僅支援從基本的多語種平面字元 (0×0000-0xFFFF)。請嘗試存儲一個同義詞相反:)

更新: MySQL 5.5.3 上 (其中尚未 GA), 支援補充字元如果您使用 UTF8MB4 編碼。

json_encode中文的時候,會把每個中文字元encode成“uxxxx”

而存進資料庫的時候,“”被遮罩了,直接變成”uxxxx”

2. 解決問題:

知道是什麼原因就好解決問題了,你可以選擇其他存儲方式;

或者再對症下藥進一步轉義””為“\”,以保留””

我們的解決方案:

1. 避免json_encode將中文轉換unicode編碼.

PHP5.4版本,已經給Json新增了一個選項: JSON_UNESCAPED_UNICODE。加上這個選項後,就不會自動把中文編碼了。

$test = json_encode("深圳", JSON_UNESCAPED_UNICODE);

 

2. 先將中文欄位urlencode,json_encode後,再用urldecode,也可以保證中文不會被轉成unicode。

$test =urldecode(json_encode(array('brief'=>urlencode(& amp;#039;簡介'),'title'=>urlencode(標題)));


3. 進一步轉義””為“\” 避免unicode中文前’'被mysql當成特殊字元去除

 

arrow
arrow
    文章標籤
    php json 中文亂碼
    全站熱搜

    痞客興 發表在 痞客邦 留言(0) 人氣()