php解決json_Encode中国語UNICODトランスコード問題(文字化けし)
2919 ワード
PHPのjsonでencodeが中国語を扱う場合、中国語はいずれも符号化され、読めない、似たような「u***」のフォーマットになりますが、漢字をトランスコードしないためには、ここで2つの方法を提供します
1.PHPをアップグレードし、PHP 5を使用する.4以上のバージョンでこの問題はやっと解決され、Jsonは新しい選択肢を追加しました:JSON_UNESCAPED_UNICode、だから名前が不思議で、つまりJsonはUnicodeをコードしないでください.
/**************************************************************
*
*特定の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();
?>
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();
?>