PHP读取mssql,json数据中文乱码 - StarkSoft
程序员文章站
2022-05-20 14:34:32
...
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);//用于调试 $query = iconv("utf-8", "gbk//ignore", $query);//为了解决中文乱码问题 if($result = sqlsrv_query($conn, $query)){ echo true; }else{ echo false; } // echo $query; ?>
推荐阅读
-
php读取mysql中文数据出现乱码的解决方法
-
php查询到的数据乱码和转json时中文变成了Unicode的编码怎么解决?
-
php连接mssql数据库中文乱码有关问题
-
php读取mysql中文数据出现乱码的解决方法
-
apache - ajax +json +php提交mysql数据库 中文乱码(wamp server 本地测试)求解?
-
PHP读取mssql json数据中文乱码的解决办法_php实例
-
PHP从数据库读取中文信息乱码
-
apache - ajax +json +php提交mysql数据库 中文乱码(wamp server 本地测试)求解?
-
PHP读取mssql json数据中文乱码的解决办法
-
PHP读取mssql json数据中文乱码的解决办法_php实例