PHP及网页使用UTF-8编码,数据库是sql server2008,使用默认编码(936,即GBK编码)
当读取数据库数据时,使用PHP自带的json_encode()返回到前端,结果中文不显示。
解决办法如下:
这样,sql server 2008中的中文就可以在网页正常显示了。
如果要将中文正常插入到sql server 2008中,还要加入一条代码:$query = iconv("utf-8","gbk//ignore",$query);//为了解决中文乱码问题
完整代码如下 :
PHP;">
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);//用于调试
解决中文乱码问题
if($result = sqlsrv_query($conn,$query)){
echo true;
}else{
echo false;
}
// echo $query;
?>
原文链接:/php/19989.html