PHP 및 웹 페이지는 UTF-8 인코딩을 사용합니다. 데이터베이스는 sql server2008이며 기본 인코딩을 사용합니다. 데이터베이스 데이터를 읽을 때 PHP와 함께 제공되는 json_encode()를 사용하면 결과가 표시되지 않습니다. 중국인. 아래에서는 Script House의 편집자가 PHP로 mssql json 데이터를 중국어로 읽을 때 해결 방법을 소개합니다. 필요한 친구들은 함께 배울 수 있습니다
PHP와 웹 페이지는 UTF-8 인코딩을 사용합니다. 기본 인코딩(GBK 인코딩인 936)을 사용합니다
데이터베이스 데이터를 읽을 때 PHP와 함께 제공되는 json_encode()를 사용하여 프런트 엔드로 돌아가면 결과가 중국어로 표시되지 않습니다.
해결 방법은 다음과 같습니다.
이렇게 하면 SQL Server 2008의 중국어가 웹 페이지에서 정상적으로 표시됩니다.
SQL Server 2008에 정상적으로 중국어를 삽입하려면 $query = iconv("utf-8", "gbk//ignore", $query);//다음 코드도 추가해야 합니다. 한자 깨짐 문제 해결
전체 코드는 다음과 같습니다.
<?php /** * 如果员工编号在MySql中不存在则在MySql中插入员工记录 * 如果该员工编号已经存在则进行更新操作 */ //如果用JSON格式则要使用text/html,不能使用text/xml header("Content-Type: text/html;charset=utf-8"); // header("Content-Type: text/html;charset=GBK"); //告诉浏览器不要缓存数据 header("Cache-Control: no-cache"); require '../conn.php'; $seq = $_POST["seq"]; $employeeID = $_POST["employeeID"]; $employeeName = $_POST["employeeName"]; $department = $_POST["department"]; if(!isset($seq) || $seq == ""){//seq不存在则插入新记录 $query = "INSERT INTO employees (employeeID, employeeName, department, createTime, updateTime) VALUES (N'$employeeID',N'$employeeName',N'$department', getdate(), getdate())"; }else{//如果seq已存在则更新已有记录 $query = "UPDATE employees SET employeeID='$employeeID', employeeName='$employeeName',department='$department', updateTime=getdate() WHERE seq='$seq'"; } // file_put_contents("E:/mylog.log", $query."\r\n",FILE_APPEND);//用于调试 <span style="color:#FF0000;">$query = iconv("utf-8", "gbk//ignore", $query);//为了解决中文乱码问题</span> if($result = sqlsrv_query($conn, $query)){ echo true; }else{ echo false; } // echo $query; ?>
요약: 위 내용은 이 글의 전체 내용입니다. 모든 분들의 학습에 도움이 되기를 바랍니다.
관련 추천:
phpCodeIgniter 기반의 이미지 업로드 및 잘라내기 기능 구현 방법
의 localeconv() 함수 예제에 대한 설명
위 내용은 PHP로 mssql json 데이터를 읽을 때 중국어 한자가 깨졌을 때 해결 방법 정보의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!