zoukankan      html  css  js  c++  java
  • PHP语言中使用JSON和将json还原成数组

    从5.2版本开始,PHP原生提供json_encode()和json_decode()函数,前者用于编码,后者用于解码。

    一、json_encode()

    1
    2
    3
    4
    <?php
    $arr array ('a'=>1,'b'=>2,'c'=>3,'d'=>4,'e'=>5);
    echo json_encode($arr);
    ?>

    输出

    1
    {"a":1,"b":2,"c":3,"d":4,"e":5}

    再看一个对象转换的例子:

    1
    2
    3
    4
    5
    6
    $obj->body           = 'another post';
    $obj->id             = 21;
    $obj->approved       = true;
    $obj->favorite_count = 1;
    $obj->status         = NULL;
    echo json_encode($obj);

     输出

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    {
       "body":"another post",
     
       "id":21,
     
       "approved":true,
     
       "favorite_count":1,
     
       "status":null
     }

     由于json只接受utf-8编码的字符,所以json_encode()的参数必须是utf-8编码,否则会得到空字符或者null。当中文使用GB2312编码,或者外文使用ISO-8859-1编码的时候,这一点要特别注意。

    二、索引数组和关联数组

    PHP支持两种数组,一种是只保存"值"(value)的索引数组(indexed array),另一种是保存"名值对"(name/value)的关联数组(associative array)。

    由于javascript不支持关联数组,所以json_encode()只将索引数组(indexed array)转为数组格式,而将关联数组(associative array)转为对象格式。

    比如,现在有一个索引数组

    1
    2
    3
    $arr = Array('one''two''three');
     
    echo json_encode($arr);

     输出

    1
    ["one","two","three"]

     如果将它改为关联数组:

    1
    2
    3
    $arr = Array('1'=>'one''2'=>'two''3'=>'three');
     
    echo json_encode($arr);

     输出变为

    1
    {"1":"one","2":"two","3":"three"}

     注意,数据格式从"[]"(数组)变成了"{}"(对象)。

    如果你需要将"索引数组"强制转化成"对象",可以这样写

    1
    json_encode( (object)$arr );

     或者

    1
    json_encode ( $arr, JSON_FORCE_OBJECT );

     三、类(class)的转换

    下面是一个PHP的类:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    class Foo {
     
      const     ERROR_CODE = '404';
     
      public    $public_ex 'this is public';
     
      private   $private_ex 'this is private!';
     
      protected $protected_ex 'this should be protected';
     
      public function getErrorCode() {
     
        return self::ERROR_CODE;
     
      }
     
    }

     现在,对这个类的实例进行json转换:

    1
    2
    3
    4
    5
    $foo new Foo;
     
    $foo_json = json_encode($foo);
     
    echo $foo_json;

     输出结果是

    1
    {"public_ex":"this is public"}

     可以看到,除了公开变量(public),其他东西(常量、私有变量、方法等等)都遗失了。

    四、json_decode()

    该函数用于将json文本转换为相应的PHP数据结构。下面是一个例子:

    1
    2
    3
    4
    5
    $json '{"foo": 12345}';
     
    $obj = json_decode($json);
     
    print $obj->{'foo'}; // 12345

     通常情况下,json_decode()总是返回一个PHP对象,而不是数组。比如:

    1
    2
    3
    $json '{"a":1,"b":2,"c":3,"d":4,"e":5}';
     
    var_dump(json_decode($json));

     结果就是生成一个PHP对象:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    object(stdClass)#1 (5) {
     
      ["a"] => int(1)
      ["b"] => int(2)
      ["c"] => int(3)
      ["d"] => int(4)
      ["e"] => int(5)
     
    }

     如果想要强制生成PHP关联数组,json_decode()需要加一个参数true:

    1
    2
    3
    $json '{"a":1,"b":2,"c":3,"d":4,"e":5}';
      
     var_dump(json_decode($json,true));

     结果就生成了一个关联数组:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    array(5) {
     
       ["a"] => int(1)
       ["b"] => int(2)
       ["c"] => int(3)
       ["d"] => int(4)
       ["e"] => int(5)
     
    }

    五、json_decode()的常见错误

    下面三种json写法都是错的,你能看出错在哪里吗?

    1
    2
    3
    4
    5
    $bad_json "{ 'bar': 'baz' }";
     
    $bad_json '{ bar: "baz" }';
     
    $bad_json '{ "bar": "baz", }';

     对这三个字符串执行json_decode()都将返回null,并且报错。

    第一个的错误是,json的分隔符(delimiter)只允许使用双引号,不能使用单引号。第二个的错误是,json名值对的"名"(冒号左边的部分),任何情况下都必须使用双引号。第三个的错误是,最后一个值之后不能添加逗号(trailing comma)。

    另外,json只能用来表示对象(object)和数组(array),如果对一个字符串或数值使用json_decode(),将会返回null。

    1
    var_dump(json_decode("Hello World")); //null
  • 相关阅读:
    区分.net中的virtual new 与override
    DOM
    两个php函数
    中文字符,全角字符的正则表达式
    CSS实现居中代码大全
    xp纯净版
    A Visit to Two National Parks: Mount Rainier and Valley Forge
    8、检测浏览器和操作系统
    客户
    American History: The Reagan Years
  • 原文地址:https://www.cnblogs.com/yeyublog/p/6230468.html
Copyright © 2011-2022 走看看