当前位置: 移动技术网 > IT编程>开发语言>PHP > PHP读取mssql json数据中文乱码的解决办法

PHP读取mssql json数据中文乱码的解决办法

2017年12月12日  | 移动技术网IT编程  | 我要评论

西瓜刀法,姓名及区位码,猫扑健康

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数据中文乱码的解决办法,希望对大家有所帮助!

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网