将JSON或XML API响应保存到Wordpress数据库

时间:2011-08-24 10:29:36

标签: xml database json wordpress api

我正在研究项目,我正在尝试将摄影师的Flickr帐户与他的Wordpress网站集成。想法是将Wordpress网站与他的flickr同步。

我正在使用Flickr API获取他的照片URL,描述,标签和设置并显示每一个。问题是,对于每次访问,我都必须完成整个API响应并解析它。必须提取所有链接,标签,描述等。

我正在寻找一种方法将此API响应(XML或JSON)“导入”到wordpress数据库并使用此数据。一旦他更新了他的flickr帐户,我就可以选择更新数据库(或者可能只是数据库中的表)。此更新不需要是自动的。

1 个答案:

答案 0 :(得分:1)

以下只是一个概念验证,并在仪表板中创建一个菜单项,其中包含Flickr API响应的结果。

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']
    );
}

我会将这些结果的操作留给读者。

建议:

  • 设置一个cron作业来提取信息并完成你的工作。使用此作为参考:Website widget to display Apple App store price drops?
  • 创建一个选项页面,并使用缩略图,扩展信息和按钮显示结果,以分发某些操作(图像侧加载,创建新帖子等),请参阅herehere

WordPress StackExchange充满了很好的片段和技巧。