PHP讀取mssql json資料中文亂碼的解決辦法,
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/xmlheader("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);//用於調試$query = iconv("utf-8", "gbk//ignore", $query);//為瞭解決中文亂碼問題if($result = sqlsrv_query($conn, $query)){echo true;}else{echo false;}// echo $query;?>
以上所述是小編給大家介紹的PHP讀取mssql json資料中文亂碼的解決辦法,希望對大家有所協助!
您可能感興趣的文章:
- php adodb串連mssql解決亂碼問題
- 探討PHP JSON中文亂碼的解決方案詳解
- PHP json_encode中文亂碼問題的解決辦法
- thinkphp3查詢mssql資料庫亂碼解決方案分享
- php中json_encode處理gbk與gb2312中文亂碼問題的解決方案
- php中json_encode UTF-8中文亂碼的更好解決方案
- php查詢mssql出現亂碼的解決方案
- PHP json_encode() 函數詳解及中文亂碼問題
http://www.bkjia.com/PHPjc/1119975.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/1119975.htmlTechArticlePHP讀取mssql json資料中文亂碼的解決辦法, PHP及網頁使用UTF-8編碼,資料庫是sql server2008,使用預設編碼(936,即GBK編碼) 當讀取資料庫資料...