热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

PHP数组传递给JavaScript以及json_encode的gbk中文乱码

文章介绍了关于PHP数组传递给JavaScript以及json_encode的gbk中文乱码的解决,下面是创建JSON函数,这一段来自网上某一位大侠**********

文章介绍了关于PHP数组传递给Javascript以及json_encode的gbk中文乱码的解决 ,下面是创建JSON函数,这一段来自网上某一位大侠

  1. /************************************************************** 
  2.  * 
  3. *    使用特定function对数组中所有元素做处理 
  4. *    @param    string    &$array        要处理的字符串 
  5. *    @param    string    $function    要执行的函数 
  6. *    @return boolean    $apply_to_keys_also        是否也应用到key上 
  7. *    @access public 
  8. * 
  9. *************************************************************/ 
  10. function arrayRecursive(&$array$function$apply_to_keys_also = false) 
  11.     foreach ($array as $key => $value) { 
  12.         if (is_array($value)) { 
  13.             arrayRecursive($array[$key], $function$apply_to_keys_also); 
  14.         } else { 
  15.             $array[$key] = $function($value); 
  16.         } 
  17.         if ($apply_to_keys_also && is_string($key)) { 
  18.             $new_key = $function($key); 
  19.             if ($new_key != $key) { 
  20.                 $array[$new_key] = $array[$key]; 
  21.                 unset($array[$key]); 
  22.             } 
  23.         } 
  24.     } 
  25. /************************************************************** 
  26.  * 
  27. *    将数组转换为JSON字符串(兼容中文) 
  28. *    @param    array    $array        要转换的数组 
  29. *    @return string        转换得到的json字符串 
  30. *    @access public 
  31. * 
  32. *************************************************************/ 
  33. function JSON($array) { 
  34.     arrayRecursive($array'urlencode', true); 
  35.     $json = json_encode($array); 
  36.     return urldecode($json); 
  37. 连接数据库取值给数组$array1 
  38.  代码如下  
  39. $dbcnx = @mysql_connect ( "localhost""root""1234" ); 
  40. if (! $dbcnx) { 
  41.     echo ("Unable to connect to the " . "database server at this time."); 
  42.     exit (); 
  43. if (! @mysql_select_db ( "pms" )) { 
  44.     echo ("Unable to locate the joke " . "database at this time."); 
  45.     exit (); 
  46. mysql_query ( "SET NAMES 'GB2312'" ); 
  47.     $q=mysql_query("select * from ability where ALV = 1");  
  48.     while($row=mysql_fetch_array($q)){  
  49.      $array1[] = $row[AName]; 

数组array1传递到Javascript给数组ability1

  1.  
  2.  

另一种json中文乱码解决方法,如果是中文的话就要注意了,在网上找到一种解决方法:

  1. /* 处理json_encode中文乱码 */  
  2. $data = array ('game' => '冰火国度''name' => '刺之灵''country' => '冰霜国''level' => 45 );  
  3. echo json_encode ( $data );  
  4. echo "
    "
    ;  
  5. $newData = array ();  
  6. foreach ( $data as $key => $value ) {  
  7. $newData [$key] = urlencode ( $value );  
  8. }  
  9. echo urldecode ( json_encode ( $newData ) );  
  10. ?> 
后来请教了别人,还可以用base64编码,不过base64编码不可以放在URL中,百度是这样解释的:标准的Base64并不适合直接放在URL里传输,因为URL编码器会把标准Base64中的“/”和“+”字符变为形如“%XX”的形式,而这些“%”号在存入数据库时还需要再进行转换,因为ANSI SQL中已将“%”号用作通配符。

不过我的数据是要通过POST发送的,并不在HTTP 的head中,而在message-body里,所以不受影响。

json_encode 只能接受utf-8格式的数据

例如:'胥'经过json_encode处理后变为'u80e5',最终的json中中文部分被替换为unicode编码。我们要解决的就是将对象转换为json并保证对象内部的中文在json中仍然是以正常的中文出现,现在看来只使用json_encode是不能达到目的的.

我的解决方法:先将类中的中文字段进行url编码(urlencode),然后再对对象进行json编码(jsonencode),最后url解码(urldecode)json,即最终的json,里面的中文依旧是那个中文! 测试代码如下:

  1. class myClass {  
  2. public $item1 = 1;  
  3. public $item2 = '中文';  
  4. function to_json() {  
  5. //url编码,避免json_encode将中文转为unicode  
  6. $this->item2 = urlencode($this->item2);  
  7. $str_json = json_encode($this);  
  8. //url解码,转完json后将各属性返回,确保对象属性不变  
  9. $this->item2 = urldecode($this->item2);  
  10. return urldecode($str_json);  
  11. }  
  12. }  
  13. $c = new myClass();  
  14. echo json_encode($c);  
  15. echo '
    '
    ;  
  16. echo $c->to_json();  
  17. echo '
    '
    ;  
  18. echo json_encode($c);  
  19. echo '
    '
    ;  
  20. echo json_encode('胥');  
  21. ?> 

程序输出结果:

  1. {"item1":1,"item2":"u4e2du6587"}  
  2. {"item1":1,"item2":"中文"}  
  3. {"item1":1,"item2":"u4e2du6587"}  
  4. "u80e5" 

推荐阅读
  • PHP 编程疑难解析与知识点汇总
    本文详细解答了 PHP 编程中的常见问题,并提供了丰富的代码示例和解决方案,帮助开发者更好地理解和应用 PHP 知识。 ... [详细]
  • 根据最新发布的《互联网人才趋势报告》,尽管大量IT从业者已转向Python开发,但随着人工智能和大数据领域的迅猛发展,仍存在巨大的人才缺口。本文将详细介绍如何使用Python编写一个简单的爬虫程序,并提供完整的代码示例。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 本文详细介绍了如何通过多种编程语言(如PHP、JSP)实现网站与MySQL数据库的连接,包括创建数据库、表的基本操作,以及数据的读取和写入方法。 ... [详细]
  • MySQL 数据库迁移指南:从本地到远程及磁盘间迁移
    本文详细介绍了如何在不同场景下进行 MySQL 数据库的迁移,包括从一个硬盘迁移到另一个硬盘、从一台计算机迁移到另一台计算机,以及解决迁移过程中可能遇到的问题。 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 本文详细介绍了如何使用 Yii2 的 GridView 组件在列表页面实现数据的直接编辑功能。通过具体的代码示例和步骤,帮助开发者快速掌握这一实用技巧。 ... [详细]
  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
  • 解决PHP与MySQL连接时出现500错误的方法
    本文详细探讨了当使用PHP连接MySQL数据库时遇到500内部服务器错误的多种解决方案,提供了详尽的操作步骤和专业建议。无论是初学者还是有经验的开发者,都能从中受益。 ... [详细]
  • Composer Registry Manager:PHP的源切换管理工具
    本文介绍了一个用于Composer的源切换管理工具——Composer Registry Manager。该项目旨在简化Composer包源的管理和切换,避免与常见的CRM系统混淆,并提供了详细的安装和使用指南。 ... [详细]
  • 本文详细介绍了Git分布式版本控制系统中远程仓库的概念和操作方法。通过具体案例,帮助读者更好地理解和掌握如何高效管理代码库。 ... [详细]
  • 深入解析JMeter中的JSON提取器及其应用
    本文详细介绍了如何在JMeter中使用JSON提取器来获取和处理API响应中的数据。特别是在需要将一个接口返回的数据作为下一个接口的输入时,JSON提取器是一个非常有用的工具。 ... [详细]
author-avatar
双鱼獒主
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有