zoukankan      html  css  js  c++  java
  • (转载)PHP json_encode() 函数介绍

    (转载)

    在 php 中使用 json_encode() 内置函数(php > 5.2)可以使用得 php 中数据可以与其它语言很好的传递并且使用它。

    这个函数的功能是将数值转换成json数据存储格式。

    <?php
    $arr = array
           (
              'Name'=>'希亚',
              'Age'=>20
           );
    
    $jsonencode = json_encode($arr);
    echo $jsonencode;
    ?>

    程序运行结果如下:

    {"Name":null,"Age":20}

         json_encode 函数中中文被编码成 null 了,Google 了一下,很简单,为了与前端紧密结合,Json 只支持 utf-8 编码,我认为是前端的 Javascript 也是 utf-8 的原因。

    <?php
    $array = array
        (
             'title'=>iconv('gb2312','utf-8','这里是中文标题'),
            'body'=>'abcd...'
        );
    
    echo json_encode($array);
    ?>

    这个程序的运行结果为:

    {"title":"u8fd9u91ccu662fu4e2du6587u6807u9898","body":"abcd..."}

    数组中所有中文在json_encode之后都不见了或者出现u2353等。

    解决方法是用urlencode()函数处理以下,在json_encode之前,把所有数组内所有内容都用urlencode()处理一下,然用json_encode()转换成json字符串,最后再用urldecode()将编码过的中文转回来。

    <?php
    /**************************************************************
     *
     *    使用特定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)
    {
        static $recursive_counter = 0;
        if (++$recursive_counter > 1000) {
            die('possible deep recursion attack');
        }
        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]);
                }
            }
        }
        $recursive_counter--;
    }
     
    /**************************************************************
     *
     *    将数组转换为JSON字符串(兼容中文)
     *    @param    array    $array        要转换的数组
     *    @return string        转换得到的json字符串
     *    @access public
     *
     *************************************************************/
    function JSON($array) {
        arrayRecursive($array, 'urlencode', true);
        $json = json_encode($array);
        return urldecode($json);
    }
    
    $array = array
           (
              'Name'=>'希亚',
              'Age'=>20
           );
    
    
    echo JSON($array);
    ?>

    这次成功了,运行结果如下:

    {"Name":"希亚","Age":"20"}

    例子:

    <?php
    $arr = array(
        'Name'=>'zhuhai',
        'Age'=>20
    );
    
    $js = json_encode($arr);  // 转化为json格式的数据
    echo $js.'<br>';
    
    $dejs = json_decode($js);  // 将json格式的数据转化为对象
    var_dump($dejs);
    ?>

    输出:

    {"Name":"zhuhai","Age":20}
    object(stdClass)#1 (2) { ["Name"]=> string(6) "zhuhai" ["Age"]=> int(20) } 
  • 相关阅读:
    洛谷P4587 [FJOI2016]神秘数(主席树)
    洛谷P4609 [FJOI2016]建筑师(第一类斯特林数+组合数)
    Bzoj4016/洛谷P2993 [FJOI2014] 最短路径树问题(最短路径问题+长链剖分/点分治)
    Bzoj1486/洛谷P3199 最小圈(0/1分数规划+spfa)/(动态规划+结论)
    Bzoj4753/洛谷P4432 [JSOI2016]最佳团体(0/1分数规划+树形DP)
    Bzoj3197/洛谷3296 [SDOI2013]刺客信条assassin(树的重心+树Hash+树形DP+KM)
    关于二分图的完美匹配问题
    Bzoj3837 [Pa2013]Filary(随机化)
    Bzoj3566/洛谷P4284 [SHOI2014]概率充电器(概率dp)
    杜教筛学习笔记
  • 原文地址:https://www.cnblogs.com/Robotke1/p/3209717.html
Copyright © 2011-2022 走看看