PHP와 웹페이지는 UTF-8 인코딩을 사용하며 데이터베이스는 sql server2008이며 기본 인코딩(GBK 인코딩인 936)을 사용합니다.
데이터베이스 데이터를 읽을 때 json_encode( PHP와 함께 제공되는))가 프런트 엔드로 돌아가면 결과가 중국어로 표시되지 않습니다.
해결 방법은 다음과 같습니다.
이렇게 하면 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>$query = iconv("utf-8", "gbk//ignore", $query);//为了解决中文乱码问题</span> if($result = sqlsrv_query($conn, $query)){ echo true; }else{ echo false; } // echo $query; ?>
위 내용은 편집자가 소개한 PHP 읽기 mssql json 데이터의 중국어 왜곡된 문자에 대한 솔루션이 모든 사람에게 도움이 되기를 바랍니다!
위 내용은 mssql을 포함하여 중국어로 왜곡된 mssql json 데이터를 읽는 PHP용 솔루션을 소개하고 있으며, PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.