-
PHP数组传递给JavaScript以及json_encode的gbk中文乱码
文章介绍了关于PHP数组传递给JavaScript以及json_encode的gbk中文乱码的解决 ,下面是创建JSON函数,这一段来自网上某一位大侠
- /**************************************************************
- *
- * 使用特定function对数组中所有元素做处理
- * @param string &$array 要处理的字符串
- * @param string $function 要执行的函数
- * @return boolean $apply_to_keys_also 是否也应用到key上
- * @access public
- *
- *************************************************************/
- function arrayRecursive(&$array, $function, $apply_to_keys_also = false)
- {
- foreach ($array as $key => $value) {
- if (is_array($value)) {
- arrayRecursive($array[$key], $function, $apply_to_keys_also);
- } else {
- $array[$key] = $function($value);
- }
- if ($apply_to_keys_also && is_string($key)) {
- $new_key = $function($key);
- if ($new_key != $key) {
- $array[$new_key] = $array[$key];
- unset($array[$key]);
- }
- }
- }
- }
- /**************************************************************
- *
- * 将数组转换为JSON字符串(兼容中文)
- * @param array $array 要转换的数组
- * @return string 转换得到的json字符串
- * @access public
- *
- *************************************************************/
- function JSON($array) {
- arrayRecursive($array, 'urlencode', true);
- $json = json_encode($array);
- return urldecode($json);
- }
- 连接数据库取值给数组$array1
- 代码如下 复制代码
- $dbcnx = @mysql_connect ( "localhost", "root", "1234" );
- if (! $dbcnx) {
- echo ("Unable to connect to the " . "database server at this time.");
- exit ();
- }
- if (! @mysql_select_db ( "pms" )) {
- echo ("Unable to locate the joke " . "database at this time.");
- exit ();
- }
- mysql_query ( "SET NAMES 'GB2312'" );
- $q=mysql_query("select * from ability where ALV = 1");
- while($row=mysql_fetch_array($q)){
- $array1[] = $row[AName];
- }
数组array1传递到JavaScript给数组ability1
- <script type="text/javascript" src="JS/jquery-1.7.2.min.js"></script>
- <script type="text/javascript">
- var ability1=<?php echo JSON($array1);?>;
- var a=eval("ability1");
- alert(a[0]);
- </script>
另一种json中文乱码解决方法,如果是中文的话就要注意了,在网上找到一种解决方法:
- <?php
- /* 处理json_encode中文乱码 */
- $data = array ('game' => '冰火国度', 'name' => '刺之灵', 'country' => '冰霜国', 'level' => 45 );
- echo json_encode ( $data );
- echo "<br>";
- $newData = array ();
- foreach ( $data as $key => $value ) {
- $newData [$key] = urlencode ( $value );
- }
- echo urldecode ( json_encode ( $newData ) );
- ?>
后来请教了别人,还可以用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,里面的中文依旧是那个中文! 测试代码如下:
- <?php
- class myClass {
- public $item1 = 1;
- public $item2 = '中文';
- function to_json() {
- //url编码,避免json_encode将中文转为unicode
- $this->item2 = urlencode($this->item2);
- $str_json = json_encode($this);
- //url解码,转完json后将各属性返回,确保对象属性不变
- $this->item2 = urldecode($this->item2);
- return urldecode($str_json);
- }
- }
- $c = new myClass();
- echo json_encode($c);
- echo '<br/>';
- echo $c->to_json();
- echo '<br/>';
- echo json_encode($c);
- echo '<br/>';
- echo json_encode('胥');
- ?>
程序输出结果:
- {"item1":1,"item2":"u4e2du6587"}
- {"item1":1,"item2":"中文"}
- {"item1":1,"item2":"u4e2du6587"}
- "u80e5"
出处:http://www.phpfensi.com/php/20131202/686.html
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式