Сохранение ответа JSON или XML API в базу данных Wordpress - PullRequest
2 голосов
/ 24 августа 2011

Я работаю над проектом и пытаюсь интегрировать аккаунт фотографа Flickr с его веб-сайтом Wordpress.Идея состоит в том, чтобы синхронизировать веб-сайт Wordpress с его flickr.

Я использую Flickr API, чтобы получать его изображения URL-адреса, описания, теги и наборы и отображать все.Проблема в том, что при каждом посещении мне приходится просматривать весь ответ API и анализировать его.Нужно извлечь все ссылки, теги, описания и т. Д.

Я ищу способ «импортировать» этот ответ API (XML или JSON) в базу данных wordpress и работать с этими данными.У меня будет возможность обновить базу данных (или, может быть, просто таблицу в базе данных), как только он обновит что-то в своей учетной записи на flickr.Это обновление не обязательно должно быть автоматическим.

1 Ответ

1 голос
/ 30 ноября 2012

Следующее является лишь подтверждением концепции и создает на панели инструментов пункт меню с результатами ответа API Flickr.

add_action( 'admin_menu', function() 
{
    add_menu_page( 
        'Flicker', 
        'Flicker', 
        'add_users', 
        'fck_admin',
        'consult_flickr_api_so_7173971', 
        'http://i.stack.imgur.com/s2ons.png',
        2
    );  
});

function consult_flickr_api_so_7173971() 
{
    $api_key = 'YOUR-KEY';
    $secret_key = 'YOUR-SECRET'; // not needed for public data
    $uid = 'USER-ID-TO-CONSULT';
    $url = 'https://api.flickr.com/services/rest/?&method=flickr.people.getPublicPhotos&api_key=' 
         . $api_key 
         . '&user_id=' 
         . $uid 
         . '&format=json&nojsoncallback=1&per_page=15'; // maximum 500
    $flickr = wp_remote_get( $url, array( 'timeout' => 120, 'httpversion' => '1.1' ) );   
    if ( $flickr['response']['code'] == '200' )
    {        
        $flickr_array = json_decode( $flickr['body'], true );
        foreach( $flickr_array['photos']['photo'] as $photo )
        {
            echo '<h2>' . $photo['title'] . '</h2>';
            get_flickr_photo_so_7173971( $photo['id'] );
        }
    }
}

/**
http://www.flickr.com/services/api/
Useful Methods
 - getExif
 - getInfo
 - getSizes
*/
function get_flickr_photo_so_7173971( $photo_id, $method = 'getSizes' )
{
    $api_key = 'YOUR-KEY';
    $flickr = wp_remote_get( 
        'https://api.flickr.com/services/rest/?&method=flickr.photos.'
        . $method
        . '&api_key=' 
        . $api_key
        . '&photo_id='
        . $photo_id
        . '&format=json&nojsoncallback=1',
        array(
             'timeout' => 120, 
            'httpversion' => '1.1' 
        ) 
    );

    if ( $flickr['response']['code'] == '200' )
    {
        $flickr_array = json_decode( $flickr['body'], true );        
        $no_print = true;
        foreach( $flickr_array['sizes']['size'] as $size ) 
        {
            if( $size['label'] == 'Medium' ) {
                print_photo_so_7173971( $size );
                $no_print = false;
            } 
        }
        // No medium size was found, just print the first one
        if( $no_print ) 
        {
            print_photo_so_7173971( $flickr_array['sizes']['size'][0] );
        }
    }
}

function print_photo_so_7173971( $size ) 
{
    printf( 
        '<img src="%s" width="%s" height="%s" /><br />',
        $size['source'],
        $size['width'],
        $size['height']
    );
}

Я оставлю манипулирование этими результатами читателю.

Предложения:

WordPress StackExchange полон хороших фрагментов и техник.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...