将数组数据作为对象附加到json文件

时间:2013-08-19 05:34:46

标签: php json file

我有一个简单的json文件,它有一个直接的图像链接和每个json对象的文件夹名称:

[
        {
                "image": "http://placehold.it/350x150",
                "folder": "Small"
        },
        {
                "image": "http://placehold.it/450x250",
                "folder": "Medium"
        },
        {
                "image": "http://placehold.it/550x350",
                "folder": "Medium"
        }
]

我想从帖子中追加这两个值,但结果是一个未更改的json文件。这是PHP代码w / comments:

$directLink = $_POST['txtDirectLink'];
$category = $_POST['selectCategoriesImages'];
$util->addToJsonImageList($directLink, $category);

//decodes the json image list, merges to the decoded array a new image, then encodes back to a json file
function addToJsonImageList($link, $category) {
    $file = file_get_contents('./images_list.json', true);
    $data = json_decode($file);
    unset($file);

    $newImage = array('image' => $link, 'folder' => $category);
    //$newImage['image'] = $link;
    //$newImage['folder'] = $category;
    $result = array_merge((array)$data, (array)$newImage);

    json_encode($result);
    file_put_contents('./images_list.json', $result);
    unset($result);
}

逻辑是,将文件作为数组json_decode编码应该很简单,将新数组合并到该数组上,然后对结果进行编码并放入同一文件中。我也无法捕捉任何类型的错误。

4 个答案:

答案 0 :(得分:8)

$data = json_decode($file, true);
//When TRUE, returned objects will be converted into associative arrays.
unset($file);

$newImage = array('image' => $link, 'folder' => $category);
//$newImage['image'] = $link;
//$newImage['folder'] = $category;
$result = array_merge($data, $newImage);
//don't need to cast

参考PHP json_decode手册

修改以下代码有效(已测试)

function addToJsonImageList($link, $category) {
    $file = file_get_contents('./images_list.json', true);
    $data = json_decode($file,true);
    unset($file);
    //you need to add new data as next index of data.
    $data[] = array('image' => $link, 'folder' => $category);
    $result=json_encode($data);
    file_put_contents('./images_list.json', $result);
    unset($result);
}

编辑2 添加了大量错误报告和调试。请让我知道以下内容的输出。下面的代码未经过测试(只需输入此处)。如果发现任何语法错误,请修复。在这里已经很晚了,明天只能查看我的时间,但可以回复。

<?php
//display all errors and warnings
error_reporting(-1);
addToJsonImageList('test link', 'test category');

function addToJsonImageList($link, $category) {
    $file = file_get_contents('./images_list.json', true);
    if ($file===false)die('unable to read file');
    $data = json_decode($file,true);
    if ($data ===NULL)die('Unable to decode');
    unset($file);
    echo "data before\n";
    var_dump ($data);
    //you need to add new data as next index of data.
    $data[] = array('image' => $link, 'folder' => $category);
    echo "data after\n";
    var_dump ($data);
    $result=json_encode($data);
    if (file_put_contents('./images_list.json', $result) === false){
        die('unable to write file');
    }
    unset($result);
}
?>

答案 1 :(得分:1)

假设你有这个名为(playerJson)的.json文件

{

"Players":
   [
     {"Name":"Arun","Arm":"Gun","num":"1"},
     {"Name":"sssv","Arm":"Arc","num":"2"},
     {"Name":"Surya","Arm":"Bomb","num":"3"},
     {"Name":"sssv","Arm":"Fire","num":"4"}

   ]
}

现在我们在php(myPhpFile.php)中要做的是:(我想你是从表单加载你的数据)

<?php

$json = file_get_contents('playerJson.json');
$json_data = json_decode($json,true);

$newar = array(
           'Name'=>$_POST['nameField'] ,
           'Arm' =>$_POST['armField'],
           'Num' =>$_POST['numField']
);
//saving data in Players object...
array_push($json_data['Players'], $newar);

$json = json_encode($json_data);

file_put_contents('playerJson.json', $json);

?>

这就是全部!您的“玩家”对象中有一个新行。 但是如果你想添加一个新对象,请避免在array_push函数中的$ json_data之后的[Players]。

答案 2 :(得分:0)

你能做的就是解码json然后合并它们。

$data = json_decode(file_get_contents(./images_list.json));

$result = array_merge((array)$data, (array)$newImage);

然后输出json_encode

file_put_contents('./images_list.json', json_encode($result, JSON_FORCE_OBJECT));

答案 3 :(得分:0)

您的问题是使用以下代码行

json_encode($result);
file_put_contents('./images_list.json', $result);

您没有捕获json_encode的结果,因此您在文件中写了array

您需要将代码调整为如下所示

$result = json_encode($result);
file_put_contents('./images_list.json', $result);