Heim  >  Artikel  >  Backend-Entwicklung  >  Codierung – Ich verwende PHP, um Daten aus MySQL zu extrahieren und sie dann in Json zu konvertieren, aber warum wird auf Chinesisch ein Fragezeichen angezeigt?

Codierung – Ich verwende PHP, um Daten aus MySQL zu extrahieren und sie dann in Json zu konvertieren, aber warum wird auf Chinesisch ein Fragezeichen angezeigt?

WBOY
WBOYOriginal
2016-09-14 09:41:271267Durchsuche

Codierung – Ich verwende PHP, um Daten aus MySQL zu extrahieren und sie dann in Json zu konvertieren, aber warum wird auf Chinesisch ein Fragezeichen angezeigt?
Codierung – Ich verwende PHP, um Daten aus MySQL zu extrahieren und sie dann in Json zu konvertieren, aber warum wird auf Chinesisch ein Fragezeichen angezeigt?

Das Obige sind die Daten in meinem Datenbestand unter Verwendung der utf8_bin-Kodierung. Am Anfang habe ich utf8_unicode_ci verwendet, aber es hat immer noch nicht funktioniert.
Das Folgende ist mein PHP-Code.

<code><?php

header('Content-Type:application/json;charset=utf-8');

//定义常量参数
define('DB_HOST','localhost');
define('DB_USER','root');
define('DB_PWD','root');//密码
define('DB_NAME','Test');

$connect = mysql_connect(
   DB_HOST, 
   DB_USER, 
   DB_PWD
)or die('数据库连接失败:'.mysql_error());

mysql_select_db(DB_NAME,$connect) or die('数据库连接错误,错误信息:'.mysql_error());

//从数据库里把表的数据提出来(获取记录集)

$query = "SELECT * FROM gc_DataBase";
$result = mysql_query($query) or die('SQL错误,错误信息:'.mysql_error());

class User {
    public $id ;
    public $name ;
    public $address;
    public $phonenumber;
}
$data =array();
while ($row= mysql_fetch_array($result, MYSQL_ASSOC)){
    $user = new User();
    $user -> id = $row["id"];
    $user -> name = $row["name"];
    $user -> address = $row["address"];
    $user -> phonenumber = $row["phonenumber"];
    $data[] = $user;
}

if (function_exists('mysql_set_charset') === false) {
    mysql_query("SET NAMES UTF8",$data);
}else{
    mysql_set_charset('utf8',$data);
}

$response = array(
    'code'    => 200, 
    'message' => 'success for request',
    'data'    => $data,
);

echo urldecode(json_encode($response));

mysql_free_result($response);  //释放

mysql_close();//关闭数据库
?>

</code>

Das Letzte, was im Browser angezeigt wird, ist dieser Urin

<code>{
    "code": 200, 
    "message": "success for request", 
    "data": [
        {
            "id": "100", 
            "name": "??", 
            "address": "????", 
            "phonenumber": "13212340001"
        }, 
        {
            "id": "101", 
            "name": "??", 
            "address": "????", 
            "phonenumber": "13512340002"
        }, 
        {
            "id": "100", 
            "name": "??", 
            "address": "????", 
            "phonenumber": "13212340001"
        }, 
        {
            "id": "101", 
            "name": "??", 
            "address": "????", 
            "phonenumber": "13512340002"
        }, 
        {
            "id": "0", 
            "name": "", 
            "address": "", 
            "phonenumber": "0"
        }, 
        {
            "id": "103", 
            "name": "??", 
            "address": "????", 
            "phonenumber": "13512340005"
        }, 
        {
            "id": "103", 
            "name": "??", 
            "address": "????", 
            "phonenumber": "13512340005"
        }
    ]
}
</code>

Warum wird das Fragezeichen auf Chinesisch angezeigt? Ich möchte nur die Unicode-Kodierung

Antwortinhalt:

Codierung – Ich verwende PHP, um Daten aus MySQL zu extrahieren und sie dann in Json zu konvertieren, aber warum wird auf Chinesisch ein Fragezeichen angezeigt?
Codierung – Ich verwende PHP, um Daten aus MySQL zu extrahieren und sie dann in Json zu konvertieren, aber warum wird auf Chinesisch ein Fragezeichen angezeigt?

Das Obige sind die Daten in meinem Datenbestand unter Verwendung der utf8_bin-Kodierung. Am Anfang habe ich utf8_unicode_ci verwendet, aber es hat immer noch nicht funktioniert.
Das Folgende ist mein PHP-Code.

<code><?php

header('Content-Type:application/json;charset=utf-8');

//定义常量参数
define('DB_HOST','localhost');
define('DB_USER','root');
define('DB_PWD','root');//密码
define('DB_NAME','Test');

$connect = mysql_connect(
   DB_HOST, 
   DB_USER, 
   DB_PWD
)or die('数据库连接失败:'.mysql_error());

mysql_select_db(DB_NAME,$connect) or die('数据库连接错误,错误信息:'.mysql_error());

//从数据库里把表的数据提出来(获取记录集)

$query = "SELECT * FROM gc_DataBase";
$result = mysql_query($query) or die('SQL错误,错误信息:'.mysql_error());

class User {
    public $id ;
    public $name ;
    public $address;
    public $phonenumber;
}
$data =array();
while ($row= mysql_fetch_array($result, MYSQL_ASSOC)){
    $user = new User();
    $user -> id = $row["id"];
    $user -> name = $row["name"];
    $user -> address = $row["address"];
    $user -> phonenumber = $row["phonenumber"];
    $data[] = $user;
}

if (function_exists('mysql_set_charset') === false) {
    mysql_query("SET NAMES UTF8",$data);
}else{
    mysql_set_charset('utf8',$data);
}

$response = array(
    'code'    => 200, 
    'message' => 'success for request',
    'data'    => $data,
);

echo urldecode(json_encode($response));

mysql_free_result($response);  //释放

mysql_close();//关闭数据库
?>

</code>

Das Letzte, was im Browser angezeigt wird, ist dieser Urin

<code>{
    "code": 200, 
    "message": "success for request", 
    "data": [
        {
            "id": "100", 
            "name": "??", 
            "address": "????", 
            "phonenumber": "13212340001"
        }, 
        {
            "id": "101", 
            "name": "??", 
            "address": "????", 
            "phonenumber": "13512340002"
        }, 
        {
            "id": "100", 
            "name": "??", 
            "address": "????", 
            "phonenumber": "13212340001"
        }, 
        {
            "id": "101", 
            "name": "??", 
            "address": "????", 
            "phonenumber": "13512340002"
        }, 
        {
            "id": "0", 
            "name": "", 
            "address": "", 
            "phonenumber": "0"
        }, 
        {
            "id": "103", 
            "name": "??", 
            "address": "????", 
            "phonenumber": "13512340005"
        }, 
        {
            "id": "103", 
            "name": "??", 
            "address": "????", 
            "phonenumber": "13512340005"
        }
    ]
}
</code>

Warum wird das Fragezeichen auf Chinesisch angezeigt? Ich möchte nur die Unicode-Kodierung

<code>if (function_exists('mysql_set_charset') === false) {
    mysql_query("SET NAMES UTF8",$data);
}else{
    mysql_set_charset('utf8',$data);
}</code>

Dieser Absatz sollte vor mysql_query stehen. Außerdem sollte der zweite Parameter an diesen beiden Stellen nicht $data sein, sondern $connect

Ich bin schon einmal auf dieses Problem gestoßen und nach dem Hinzufügen mysqli_query($conn,"SET NAMES utf8");

war alles in Ordnung
<code>class DBHelper{
    
    public function DBHelper(){}
    
    private static function getConn(){
        $conn = mysqli_connect(DB_HOST,DB_USER,DB_PWD,DB_NAME);
        mysqli_query($conn,"SET NAMES utf8");
        return $conn;
    }
    
    public static function opearting($sql){
        return mysqli_query(self::getConn(),$sql);
        
    }
}</code>

Das Problem mit der Kodierung des chinesischen URL-Codes, auf das ich gestoßen bin, kann nicht direkt dekodiert werden. Andernfalls werden verstümmelte Zeichen angezeigt. Die Art und Weise, wie ich es benutze, ist.
Individuell kodiert. Dann Dekodierung: ` /**

<code> * [ReturnUrlencode 用递归的方式来遍历所有的数组并且解析]
 * @param [type] $arr [description]
 */
function ReturnUrlencode($arr){
    foreach ($arr as $key => $value){
        if(is_array($value)){   
            $arr[$key]=ReturnUrlencode($value);
        }else{
            $arr[$key]=urlencode($value);
        }
    }
    return $arr;
}`

##这种方式,输出来的json 中文就不会乱码了。
urldecode(json_encode(ReturnUrlencode($arr)));</code>

<code class="php">if (function_exists('mysql_set_charset') === false) {
    mysql_query("SET NAMES UTF8",$data);
}else{
    mysql_set_charset('utf8',$data);
}</code>

Dieser Satz sollte vor dem Durchlaufen der Daten platziert werden

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn