程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> PHP讀取mssql json數據中文亂碼的解決辦法

PHP讀取mssql json數據中文亂碼的解決辦法

編輯:PHP綜合

PHP及網頁使用UTF-8編碼,數據庫是sql server2008,使用默認編碼(936,即GBK編碼)

當讀取數據庫數據時,使用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;
?>

以上所述是小編給大家介紹的PHP讀取mssql json數據中文亂碼的解決辦法,希望對大家有所幫助!

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved