在foreach循环中将元素添加到关联数组

时间:2016-03-06 13:32:10

标签: php json api instagram instagram-api

我正在为Android应用创建自己的API但我似乎无法解决这个问题。 (注意这是我的第一个php项目)。

我想要实现的是将一个元素添加到关联数组然后将其编码为JSON,但我唯一能做的就是每次循环重复时对JSON进行编码,从而导致格式化的JSON格式不正确。 / p>

这是循环

的功能
function checkLike($media_id, $user1_id, $access_token){

    $url = 'https://api.instagram.com/v1/media/'.$media_id.'/likes?access_token='.$access_token;

    $json1 = file_get_contents($url);

    $arr1 = json_decode($json1);

    $arr = array('media_id' => $media_id, 'hasLiked' => 0);


    if(is_array($arr1->data)){      
        foreach ($arr1->data as $key => $value) {
            //echo 'Comprobando el id '.$value->id.' deberia ser '. $user1_id.' ';

            if($value->id === $user1_id){
                $arr = array('media_id' => $media_id, 'hasLiked' => 1);
            }else{
                echo 'nope';
            }

        }encode_json($arr);
    }else{
        echo 'false1';
    }

}

这是从

调用的另一个循环
$json = file_get_contents('https://api.instagram.com/v1/users/self/media/recent/?access_token='.$token.'&count=5');

$arr = json_decode($json);



if (is_array($arr->data)) {
    foreach ($arr->data as $key => $value) {
        checkLike($value->id, get_user_id($user, $token), $token);
    }
}

但是,我得到的JSON如下:

{"media_id":"1198059901794013237_483636171","hasLiked":0}
{"media_id":"1196611512178987610_483636171","hasLiked":1}
{"media_id":"1195162888588906891_483636171","hasLiked":1}
{"media_id":"1193726158308528216_483636171","hasLiked":1}
{"media_id":"1192260158916546943_483636171","hasLiked":1}

我需要做些什么才能得到这样的东西?

{
   "photos":[
      {
         "mediaID":"1198059901794013237_483636171",
         "hasLiked":0
         }, {
         "mediaID":"1196611512178987610_483636171",
         "hasLiked":1
         }
   ]
}

3 个答案:

答案 0 :(得分:1)

你用每个循环覆盖你的数组。在你的循环中改变这一行如下:

$arr[] = array('media_id' => $media_id, 'hasLiked' => 1);

$arr将是一个数组数组,当你在循环外调用json_encode($arr)时,你将获得一个JSON字符串中的所有数据。

这是完全固定的代码 - 这应该可行,但我还没有尝试过:

function checkLike($media_id, $user1_id, $access_token){

    $url = 'https://api.instagram.com/v1/media/'.$media_id.'/likes?access_token='.$access_token;

    $json1 = file_get_contents($url);

    $arr1 = json_decode($json1);

    // Initialize and add first element to array
    $arrJSON[] = array('media_id' => $media_id, 'hasLiked' => 0);

    if(is_array($arr1->data)){ 

        foreach ($arr1->data as $key => $value) {           

            if($value->id === $user1_id){

                // Add to $arrJSON
                $arrJSON[] = array('media_id' => $media_id, 'hasLiked' => 1);

            }else{

                echo 'nope';

            }
        }

    } else {

        echo 'false1';

    }

    // Encode entire array as JSON and echo
    echo json_encode($arrJSON);
}

答案 1 :(得分:0)

只需替换此行:

json_encode($arr);

使用:

json_encode(array("photos"=>$arr));

答案 2 :(得分:0)

好的,我试图在函数内部创建数组,但我应该在调用函数后完成它。我使用该函数返回用户喜欢照片作为布尔值。代码是:

checkLike功能

function checkLike($media_id, $user1_id, $access_token){

    $url = 'https://api.instagram.com/v1/media/'.$media_id.'/likes?access_token='.$access_token;

    $json1 = file_get_contents($url);

    $arr1 = json_decode($json1);

    $hasLiked = false;

    if(is_array($arr1->data)){      
        foreach ($arr1->data as $key => $value) {
            //echo 'Comprobando el id '.$value->id.' deberia ser '. $user1_id.' ';

            if($value->id === $user1_id){
                $hasLiked = true;
            }else{
                echo 'nope';
            }

        }
    }else{
        echo 'false';
    }

    return $hasLiked;

}

主要代码:

$json = file_get_contents('https://api.instagram.com/v1/users/self/media/recent/?access_token='.$token.'&count=5');

$media_array= json_decode($json);

if (is_array($media_array->data)) {
    foreach ($media_array->data as $key => $value) {
        $mediaID = $value->id;
        if(checkLike($mediaID, get_user_id($user, $token), $token)){
            $arrJSON[] = array('media_id' => $mediaID, 'hasLiked' => 1);
        }else{
            $arrJSON[] = array('media_id' => $mediaID, 'hasLiked' => 0);
        }
    }

    encode_json(array('photos'=>$arrJSON));
}