大家都知道,json_encode通常會(huì)把json中的漢字轉(zhuǎn)義成unicode,但是這并不一定是我們想要的。有時(shí)候,我們需要獲得漢字形式的json字符串,比如需要獲得gbk編碼的json字符串(只要把漢字形式的字符串轉(zhuǎn)碼就可以得到了)。有什么好辦法么?
php官方聽(tīng)到了這個(gè)需求,并提供了一種可靠的解決方案:JSON_UNESCAPED_UNICODE。這個(gè)參數(shù)可以保證json_encode不再將漢字轉(zhuǎn)為unicode。
似乎這樣就解決了?當(dāng)我們高高興興的用這個(gè)參數(shù)的時(shí)候,發(fā)現(xiàn)并沒(méi)有什么卵用。仔細(xì)一看,這個(gè)參數(shù)只有5.4之后的php支持。那更早期的php怎么辦呢?
社區(qū)提供了一種方案:
function my_json_encode($arr){//convmap since x char codes so it takes all multibyte codes (above ASCII ). So such characters are being "hidden" from normal json_encodingarray_walk_recursive($arr, function (&$item, $key) { if (is_string($item)) $item = mb_encode_numericentity($item, array (x, xffff, , xffff), 'UTF-'); });return mb_decode_numericentity(json_encode($arr), array (x, xffff, , xffff), 'UTF-');} 不過(guò)這種方法只有5.3才支持,因?yàn)?.2并不支持匿名函數(shù)。至于解決辦法?把匿名函數(shù)定義一下即可。
ps:解決json_encode中文UNICODE轉(zhuǎn)碼問(wèn)題
用PHP的json_encode來(lái)處理中文的時(shí)候, 中文都會(huì)被編碼, 變成不可讀的, 類似”/u***”的格式,如果想漢字不進(jìn)行轉(zhuǎn)碼,這里提供三種方法
1.升級(jí)PHP,在PHP5.4, 這個(gè)問(wèn)題終于得以解決, Json新增了一個(gè)選項(xiàng): JSON_UNESCAPED_UNICODE, 故名思議, 就是說(shuō), Json不要編碼Unicode.
<?phpecho json_encode("中文", JSON_UNESCAPED_UNICODE);//"中文" 2.把漢字先urlencode然后再使用json_encode,json_encode之后再次使用urldecode來(lái)解碼,這樣編碼出來(lái)的json數(shù)組中的漢字就不會(huì)出現(xiàn)unicode編碼了。
$array = array('test'=>urlencode("我是測(cè)試"));$array = json_encode($array);echo urldecode($array);//{"test":"我是測(cè)試"} 3.對(duì)unicode碼再進(jìn)行解碼,解碼函數(shù)如下:
function decodeUnicode($str){return preg_replace_callback('/////u([0-9a-f]{4})/i',create_function('$matches','return mb_convert_encoding(pack("H*", $matches[1]), "UTF-8", "UCS-2BE");'),$str);} 
















