PHP读取mssql2008,json数据中文乱码

PHP及网页使用UTF-8编码,数据库是sql server2008,使用默认编码(936,即GBK编码)

当读取数据库数据时,使用php自带的json_encode()返回到前端,结果中文不显示。

解决办法:

[php][/php] view plaincopy

  1. employeeGet.php
  2. <?php
  3.     header(“Content-Type: text/html;charset=utf-8”);
  4.     //告诉浏览器不要缓存数据
  5.     header(“Cache-Control: no-cache”);
  6.     require “../conn.php”;
  7.     require “../share/json_gbk2utf8.php”;
  8.     $query = ‘SELECT
  9.                 seq,
  10.                 employeeID,
  11.                 employeeName,
  12.                 department,
  13.                 position,
  14.                 sex,
  15.                 birthday,
  16.                 entryTime,
  17.                 description,
  18.                 convert(varchar(20),createTime,120) as createTime,<span style=”color:#FF0000;”>//这里要注意,因为mssql2008的datetimne类型是带有毫秒的,直接在前端显示
  19. 可能会有问题,所以要做一次转换</span>
  20.                 convert(varchar(20),updateTime,120) as updateTime
  21.             FROM employees’;
  22.     $arr = Array();
  23.     $query = iconv(“utf-8”, “gbk//ignore”, $query);//为了解决中文乱码问题
  24.     if($result = sqlsrv_query($conn, $query)){
  25.         while($row = sqlsrv_fetch_array($result)){
  26.             $arr[] = $row;
  27.         }
  28.     }
  29.     $data = JSON($arr);
  30. //  file_put_contents(“E:/mylog.log”, “JSON:”.$data.”\r\n”, FILE_APPEND);
  31.     echo $data;
  32. ?>

 

 

[php][/php] view plaincopy

  1. <?php
  2. //json_gbk2utf8.php
  3. /**************************************************************
  4.  *为了实现对含有中文字符的数组进行json编码
  5.  *
  6. *  使用特定function对数组中所有元素做处理
  7. *  @param  string  &$array     要处理的字符串
  8. *  @param  string  $function   要执行的函数
  9. *  @return boolean $apply_to_keys_also     是否也应用到key上
  10. *  @access public
  11. *
  12. *************************************************************/
  13. function arrayRecursive(&$array, $function, $apply_to_keys_also = false)
  14. {
  15.     static $recursive_counter = 0;
  16.     if (++$recursive_counter > 1000) {
  17.         die(‘possible deep recursion attack’);
  18.     }
  19.     foreach ($array as $key => $value) {
  20.         if (is_array($value)) {
  21.             arrayRecursive($array[$key], $function, $apply_to_keys_also);
  22.         } else {
  23. //          file_put_contents(“E:/mylog.log”, “原始:”.$value.”\r\n”, FILE_APPEND);
  24.             $value = iconv(“gbk//ignore”, “utf-8”, $value);
  25. //          file_put_contents(“E:/mylog.log”, “utf-8:”.$value.”\r\n”, FILE_APPEND);
  26.             $array[$key] = $function($value);
  27. //          file_put_contents(“E:/mylog.log”, “urlencode:”.$array[$key].”\r\n”, FILE_APPEND);
  28.         }
  29.         if ($apply_to_keys_also && is_string($key)) {
  30.             $new_key = $function($key);
  31.             if ($new_key != $key) {
  32.                 $array[$new_key] = $array[$key];
  33.                 unset($array[$key]);
  34.             }
  35.         }
  36.     }
  37.     $recursive_counter–;
  38. }
  39. /**************************************************************
  40.  *
  41. *  将数组转换为JSON字符串(兼容中文)
  42. *  @param  array   $array      要转换的数组
  43. *  @return string      转换得到的json字符串
  44. *  @access public
  45. *
  46. *************************************************************/
  47. function JSON($array) {
  48.     arrayRecursive($array, ‘urlencode’, true);
  49.     $json = json_encode($array);
  50.     return urldecode($json);
  51. }
  52. /*
  53. $array = array
  54. (
  55.         ‘Name’=>’希亚’,
  56.         ‘Age’=>20
  57. );
  58. echo JSON($array);
  59. */
  60. ?>

这样,sql server 2008中的中文就可以在网页正常显示了。

 

如果要将中文正常插入到sql server 2008中,还要加入一条代码:$query = iconv(“utf-8”, “gbk//ignore”, $query);//为了解决中文乱码问题

完整代码如下 :

 

[php][/php] view plaincopy

  1. <?php
  2.     /**
  3.      * 如果员工编号在MySql中不存在则在MySql中插入员工记录
  4.      * 如果该员工编号已经存在则进行更新操作
  5.      */
  6.     //如果用JSON格式则要使用text/html,不能使用text/xml
  7.     header(“Content-Type: text/html;charset=utf-8”);
  8. //  header(“Content-Type: text/html;charset=GBK”);
  9.     //告诉浏览器不要缓存数据
  10.     header(“Cache-Control: no-cache”);
  11.     require ‘../conn.php’;
  12.     $seq = $_POST[“seq”];
  13.     $employeeID = $_POST[“employeeID”];
  14.     $employeeName = $_POST[“employeeName”];
  15.     $department = $_POST[“department”];
  16.     if(!isset($seq) || $seq == “”){//seq不存在则插入新记录
  17.         $query = “INSERT INTO employees (employeeID, employeeName, department,
  18.                     createTime, updateTime)
  19.                 VALUES (N’$employeeID’,N’$employeeName’,N’$department’,
  20.                     getdate(), getdate())”;
  21.     }else{//如果seq已存在则更新已有记录
  22.         $query = “UPDATE employees SET employeeID=’$employeeID’,
  23.                 employeeName=’$employeeName’,department=’$department’,
  24.                 updateTime=getdate()
  25.             WHERE seq=’$seq'”;
  26.     }
  27. //  file_put_contents(“E:/mylog.log”, $query.”\r\n”,FILE_APPEND);//用于调试
  28.     <span style=”color:#FF0000;”>$query = iconv(“utf-8”, “gbk//ignore”, $query);//为了解决中文乱码问题</span>
  29.     if($result = sqlsrv_query($conn, $query)){
  30.         echo true;
  31.     }else{
  32.         echo false;
  33.     }
  34. //  echo $query;
  35. ?>

标签