***php解析JSON二维数组字符串(json_decode函数第二个参数True和False的区别)

客户端的请求体中的数据:[{"msg_id": 1, "msg_status": "HAS_READ" }, { "msg_id": 2, "msg_status": "HAS_READ" }] 是一个二维数组字符串
$json_data = json_decode($GLOBALS['HTTP_RAW_POST_DATA'], true);
其实用这一句即可实现JSON二维数组字符串转PHP的二维数组变量,不用自己动态构造二维数组
该函数的第二个参数很重要:不加true会以PHP对象输出, 加true输出PHP数组


   /**
     * 根据上传的消息ID集合来批量更新消息的状态
     */
    public function update_status_batch()
    {
        //需要更新的数据
/*        $data = array(
            array(
                'msg_id' => 1 ,
                'msg_status' => 'HAS_READ'
            ),
            array(
                'msg_id' => 2 ,
                'msg_status' => 'HAS_READ'
            )
        );*/

        //返回值默认是JSON对象,当第二个可选参数是TRUE的时候,则返回的是数组;如果是二维数组的JSON字符串,这里也会转换为二维数组的PHP变量
        $json_data = json_decode($GLOBALS['HTTP_RAW_POST_DATA'], true);
/*        //元素个数
        //$item_num = count($json_data);
        //定义二维数组
        $array = array();
        foreach($json_data as $item){
            $array_unit = array(
                'msg_id' => $item->msg_id,
                'msg_status' => $item->msg_status
            );
            //往二维数组追加元素
            array_push($array,$array_unit);
        }*/

        //更新,返回值是更新所影响的记录条数
        $result = $this->m_user_msg->update_batch($json_data, 'msg_id');
        if(!empty($result)){
            //如果不为空,就返回成功
            $return_data['code']= '100';
            $return_data['msg']= '处理成功';
            //需要进行字符串转数字处理
            $return_data['data']= $result;

        }else{
            $return_data['code']= '400';
            $return_data['msg']= '处理失败';
            $return_data['data']= $json_data;
        }

        //设置以JSON返回给请求方
        header('Content-Type:application/json; charset=utf-8');
        //转换为JSON字符串
        echo  stripslashes(json_encode($return_data, JSON_UNESCAPED_UNICODE)) ;

    }

 

-------------------------------------------------------------------------------------------------------

json_decode函数第二个参数True和False的区别

默认值:false,返回object对象

Array
(
[0] => stdClass Object
(
[name] => C51790CC-EDEF-4DF7-9CC7-FE8F4DC8138B&ext=JPG
[width] => 200
[height] => 149
)

[1] => stdClass Object
(
[name] => 4E6A33AD-D9AE-47CD-9711-E95D9184FBC2&ext=JPG.jpg
[width] => 160
[height] => 160
)

)

为true的情况,返回数组array:

Array
(
[0] => Array
(
[name] => C51790CC-EDEF-4DF7-9CC7-FE8F4DC8138B&ext=JPG
[width] => 200
[height] => 149
)

[1] => Array
(
[name] => 4E6A33AD-D9AE-47CD-9711-E95D9184FBC2&ext=JPG.jpg
[width] => 160
[height] => 160
)

)

 

官方解释:

json_decode

(PHP 5 >= 5.2.0, PECL json >= 1.2.0)

json_decode — 对 JSON 格式的字符串进行编码

说明

mixed json_decode ( string $json [, bool $assoc = false [, int $depth = 512 [, int $options = 0 ]]] )

接受一个 JSON 格式的字符串并且把它转换为 PHP 变量

参数

 

json

待解码的 json string 格式的字符串。

This function only works with UTF-8 encoded data.

assoc

当该参数为 TRUE 时,将返回 array 而非 object 。

depth

User specified recursion depth.

options

Bitmask of JSON decode options. Currently only JSON_BIGINT_AS_STRING is supported (default is to cast large integers as floats)

返回值

Returns the value encoded in json in appropriate PHP type. Values truefalse and null (case-insensitive) are returned as TRUEFALSE andNULL respectively. NULL is returned if the json cannot be decoded or if the encoded data is deeper than the recursion limit.

posted @ 2015-03-05 15:25  谦信君  阅读(17586)  评论(0编辑  收藏  举报