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 style="color:#FF0000;">$query = iconv("utf-8", "gbk//ignore", $query);//为了解决中文乱码问题</span> if($result = sqlsrv_query($conn, $query)){ echo true; }else{ echo false; } // echo $query; ?>
위는 한문 깨짐 mssql을 읽기 위해 에디터가 소개한 해결 방법입니다. PHP를 사용한 JSON 데이터가 모두에게 도움이 되기를 바랍니다!
PHP로 mssql json 데이터를 읽을 때 중국어 왜곡된 한자에 대한 솔루션에 대한 더 많은 관련 기사를 보려면 PHP 중국어 웹사이트를 주목하세요!