PHP及網頁使用UTF-8編碼,資料庫是sql server2008,使用預設編碼,當讀取資料庫資料時,使用php自帶的json_encode()回到前端,結果中文不顯示。下面腳本之家小編跟大家介紹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/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基於CodeIgniter實作圖片上傳、剪下功能的方法
#php metaphone()函式和php# localeconv() 函數實例詳解
#
以上是關於PHP讀取mssql json資料中文亂碼的解決辦法的詳細內容。更多資訊請關注PHP中文網其他相關文章!