PHP及网页使用UTF-8编码,数据库是sql server2008,使用默认编码(936,即GBK编码)
当读取数据库数据时,使用php自带的json_encode()返回到前端,结果中文不显示。
解决办法如下:
这样,sql server 2008中的中文就可以在网页正常显示了。
如果要将中文正常插入到sql server 2008中,还要加入一条代码:$query = iconv("utf-8", "gbk//ignore", $query);//为了解决中文乱码问题
完整代码如下 :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
<?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数据中文乱码的解决办法,希望对大家有所帮助!