本文轉自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當成特殊字元去除
留言列表