2011-01-22 2 views
0

Как я могу получить результаты Плагина регистрации Facebook и отправить его по электронной почте?Плагин регистрации Facebook?

+0

, если я хочу сохранить эти данные в базе данных, это законно? –

ответ

1

Ну, вы должны отправить то, что вы получили так far..anyway, как описано в documentation:

Данные передаются в приложение в качестве подписанного запроса. Параметр signed_request является простым способом , чтобы быть уверенным, что ваши данные получение - это фактические данные, полученные Facebook.

Таким образом, вы должны указать процесс redirect_uri и затем/извлечь данные, которые вы хотите от signed_request и отправить его с помощью метода, который вы используете. Как обрабатывать данные описан в нижней части документа я связан выше:

<?php 
define('FACEBOOK_APP_ID', 'your_app_id'); 
define('FACEBOOK_SECRET', 'your_app_secret'); 

function parse_signed_request($signed_request, $secret) { 
    list($encoded_sig, $payload) = explode('.', $signed_request, 2); 

    // decode the data 
    $sig = base64_url_decode($encoded_sig); 
    $data = json_decode(base64_url_decode($payload), true); 

    if (strtoupper($data['algorithm']) !== 'HMAC-SHA256') { 
    error_log('Unknown algorithm. Expected HMAC-SHA256'); 
    return null; 
    } 

    // check sig 
    $expected_sig = hash_hmac('sha256', $payload, $secret, $raw = true); 
    if ($sig !== $expected_sig) { 
    error_log('Bad Signed JSON signature!'); 
    return null; 
    } 

    return $data; 
} 

function base64_url_decode($input) { 
    return base64_decode(strtr($input, '-_', '+/')); 
} 

if ($_REQUEST) { 
    echo '<p>signed_request contents:</p>'; 
    $response = parse_signed_request($_REQUEST['signed_request'], 
            FACEBOOK_SECRET); 
    echo '<pre>'; 
    print_r($response); 
    echo '</pre>'; 
} else { 
    echo '$_REQUEST is empty'; 
} 
?> 

Таким образом, вместо функций print_r и echo, отправьте поле, которые вы хотите!