本文目錄一覽:
- 1、我用php輸出json 中文顯示亂碼,請大俠幫忙解決一下
- 2、php json 輸出中文亂碼的問題怎麼處理啊,謝謝
- 3、phpmysql生成json中文亂碼
- 4、PHP中json_encode中文亂碼問題
- 5、PHP從Mysql查出來的數據轉換成json格式中文亂碼怎麼解決
我用php輸出json 中文顯示亂碼,請大俠幫忙解決一下
用json_decode()方法可以把這些代碼還原為php格式,然後輸出就可以看到中文了
如下:
$js_str = 你所謂的亂碼;
$arr = json_deconde ($js_str);
print_r($arr);
php json 輸出中文亂碼的問題怎麼處理啊,謝謝
header(“Content-Type:text/html;charset=UTF-8”);
$arr=array(‘1′,’2′,’三’);
echo $arr[‘2’].”br /”;
print_r($arr);
echo “br /”;
print_r(json_encode($arr));
echo “br /”;
print_r(json_decode(json_encode($arr)));
輸出json數據會有 但是 翻譯成數組後就行了
phpmysql生成json中文亂碼
你好,這是json對中文處理後的編碼,不屬於亂碼,如果不想它編碼可以在json_encode的第二個參數加
JSON_UNESCAPED_UNICODE
。
json_encode($var,JSON_UNESCAPED_UNICODE);
PHP中json_encode中文亂碼問題
php 中使用 json_encode() 內置函數(php 5.2)可以使用得 php 中數據可以與其它語言很好的傳遞並且使用它。這個函數的功能是將數值轉換成json數據存儲格式
$arr = array (‘a’=1,’b’=2,’c’=3,’d’=4,’e’=5);
echo json_encode($arr);
//結果
//{“a”:1,”b”:2,”c”:3,”d”:4,”e”:5}
/*
下面看一款json_encode中文亂碼問題
解決方法是用urlencode()函數處理以下,在json_encode之前,把所有數組內所有內容都用urlencode()處理一下,然用json_encode()轉換成json字元串,最後再用urldecode()將編碼過的中文轉回來
*/
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)) {
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
*
*************************************************************/
function json($array) {
arrayrecursive($array, ‘urlencode’, true);
$json = json_encode($array);
return urldecode($json);
}
$array = array
(
‘name’=’希亞’,
‘age’=20
);
echo json($array);
//應用實例
$servname=”localhost”;
$sqlservname=”root”;
$sqlservpws=”123456″;
$sqlname=”lock1″;
$db=mysql教程_connect($servname,$sqlservname,$sqlservpws) or die(“資料庫教程連接失敗”);
mysql_select_db($sqlname,$db);
$sql = “select * from t_operater”;
$result =mysql_query($sql);
$rows = mysql_num_rows($result);
while($obj = mysql_fetch_object($result))
{
$arr[] = $obj;
}
echo ‘({“total”:”‘.$rows.'”,”results”:’.json_encode($arr).’})’;
PHP從Mysql查出來的數據轉換成json格式中文亂碼怎麼解決
需要保持 編碼一致 包括
1 創建一致 使用UTF8
CREATE DATABASE `test2` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
2. 鏈接編碼一致
$mysqli-query(“SET NAMES ‘UTF8′”);
3. html php 頁面聲明 編碼一致
header(“Content-Type: text/html; charset=utf-8”);
4 . 腳本文件 編碼一致
存儲腳本文件時選擇unicode UTF8
特別提示, windows 使用中文文件名和目錄名 , 默認的是GBK 要寫入非 gbk資料庫需要轉為一致的代碼
原創文章,作者:XAIGQ,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/325040.html