php解決json_Encode中国語UNICODトランスコード問題(文字化けし)

2919 ワード

PHPのjsonでencodeが中国語を扱う場合、中国語はいずれも符号化され、読めない、似たような「u***」のフォーマットになりますが、漢字をトランスコードしないためには、ここで2つの方法を提供します
1.PHPをアップグレードし、PHP 5を使用する.4以上のバージョンでこの問題はやっと解決され、Jsonは新しい選択肢を追加しました:JSON_UNESCAPED_UNICode、だから名前が不思議で、つまりJsonはUnicodeをコードしないでください.
2. PHP5.4    ,    
class ServerClass{
/**************************************************************
     *
*特定のfunctionを使用して配列内のすべての要素を処理
*@param string&$arrayで処理する文字列
*@param string$function実行する関数
     *  @return boolean $apply_to_keys_Alsoもkeyに適用されるかどうか
     *  @access public
     *
     *************************************************************/
  Public function arrayRecursive(&$array, $function, $apply_to_keys_also = false)
    {
        static $recursive_counter = 0;
        if (++$recursive_counter > 1000) {
            die('possible deep recursion attack');
        }
        foreach ($array as $key => $value) {
            if (is_array($value)) {
                self::arrayRecursive($array[$key], $function, $apply_to_keys_also);
            } else {
                $array[$key] = $function($value);
            }
            if ($apply_to_keys_also && is_string($key)) {
                $new_key = $function($key);
                if ($new_key != $key) {
                    $array[$new_key] = $array[$key];
                    unset($array[$key]);
                }
            }
        }
        $recursive_counter--;
    }
/**************************************************************
 *
*配列をJSON文字列に変換(中国語対応)
*@param array$array変換する配列
*@return string変換で得られたjson文字列
 * @access public
 *
 *************************************************************/
Public function JSON($array) {
 self::arrayRecursive($array, 'urlencode', true);//内部関数相互変調用self::
 $json = json_encode($array);
 return urldecode($json);
}
Public Function Search() {
$Conn=Mysqli_connect("localhost","a1022185526","90744321","a1022185526");//ホスト、ユーザー、パスワード、データベース
If(!$Conn) {
Die(「データベース接続に失敗しました」.mysqli_connect_error($Conn));
}
Mysqli_query($Conn,"set names utf8");
$Result=Mysqli_query($Conn,"Select * From Ruyiweb_user");
While($Row = Mysqli_fetch_assoc($Result)){
$Arr[] = $Row;
}
Mysqli_free_result($Result);
   //$Json = json_encode($Arr,JSON_UNESCAPED_UNICODE);//PHP5.4以上JSON_UNESCAPED_UNICode、だから名前が不思議で、つまりJsonはUnicodeをコードしないでください.
$Json=self::JSON($Arr);
    Mysqli_close($Conn);
Return $Json;
}
}
$serverclass1=new ServerClass();
echo $serverclass1->Search();
?>