> 백엔드 개발 > PHP 튜토리얼 > 인코딩 - PHP를 사용하여 mysql에서 데이터를 추출한 후 Json으로 변환하는데 왜 중국어로 물음표가 표시되나요?

인코딩 - PHP를 사용하여 mysql에서 데이터를 추출한 후 Json으로 변환하는데 왜 중국어로 물음표가 표시되나요?

WBOY
풀어 주다: 2016-09-14 09:41:27
원래의
1295명이 탐색했습니다.

인코딩 - PHP를 사용하여 mysql에서 데이터를 추출한 후 Json으로 변환하는데 왜 중국어로 물음표가 표시되나요?
인코딩 - PHP를 사용하여 mysql에서 데이터를 추출한 후 Json으로 변환하는데 왜 중국어로 물음표가 표시되나요?

위는 utf8_bin 인코딩을 사용하여 내 데이터 인벤토리에 있는 데이터입니다. 처음에는 utf8_unicode_ci를 사용했지만 여전히 작동하지 않았습니다.
다음은 내 PHP 코드입니다

<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>
로그인 후 복사
로그인 후 복사

브라우저에 마지막으로 표시되는 것은 이 소변입니다

<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>
로그인 후 복사
로그인 후 복사

물음표는 왜 중국어로 표시되나요? 저는 유니코드 인코딩을 원합니다

답글 내용:

인코딩 - PHP를 사용하여 mysql에서 데이터를 추출한 후 Json으로 변환하는데 왜 중국어로 물음표가 표시되나요?
인코딩 - PHP를 사용하여 mysql에서 데이터를 추출한 후 Json으로 변환하는데 왜 중국어로 물음표가 표시되나요?

위는 utf8_bin 인코딩을 사용하여 내 데이터 인벤토리에 있는 데이터입니다. 처음에는 utf8_unicode_ci를 사용했지만 여전히 작동하지 않았습니다.
다음은 내 PHP 코드입니다

<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>
로그인 후 복사
로그인 후 복사

브라우저에 마지막으로 표시되는 것은 이 소변입니다

<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>
로그인 후 복사
로그인 후 복사

물음표는 왜 중국어로 표시되나요? 저는 유니코드 인코딩을 원합니다

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

이 문단은 mysql_query 앞에 와야 합니다. 또한, 이 두 곳의 두 번째 매개변수는 $data가 아니고 $connect

이어야 합니다.

이전에 이런 문제가 발생한 적이 있는데, 추가하고 나니 괜찮았습니다mysqli_query($conn,"SET NAMES utf8");

<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>
로그인 후 복사

제가 겪은 중국어 urlencode 인코딩 문제를 직접 디코딩할 수 없습니다. 그렇지 않으면 잘못된 문자가 나타납니다. 제가 사용하는 방식은 이렇습니다.
개별적으로 인코딩됩니다. 그런 다음 ` /**

<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>
로그인 후 복사

이 문장은 데이터를 순회하기 전에 배치되어야 합니다

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿