PHP读取mssql json数据中文乱码的解决办法
程序员文章站
2024-02-11 23:48:52
php及网页使用utf-8编码,数据库是sql server2008,使用默认编码(936,即gbk编码)
当读取数据库数据时,使用php自带的json_encode...
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数据中文乱码的解决办法,希望对大家有所帮助!