-2

ユーザーが Facebook 経由で Web アプリケーションに登録できるようにしようとしています。私の通常の登録の一部として、ユーザーは自分の電子メール アドレスを提供する必要があり、Facebook の登録の一部としてこれを含める必要があります。

以下のコードを使用していますが、Facebook の応答の一部としてユーザーのメール アドレスが返されないことを除けば、正しく動作します。メールを具体的に「尋ねる」必要があることは承知していますが、以下のコードでこれをどこでどのように行うのか混乱していますか?

また、プロセスの一環としてユーザーがメール アドレスを提供しないことを選択する可能性があることも承知していますが、私はそれを処理できます。

    // Grab our facebook details
    $app_id = $this->config->item('fb_app_id');
    $app_secret = $this->config->item('fb_secret_key');
    $my_url = $this->config->item('fb_url');

    session_start();

    if(isset($_REQUEST["code"]))
    {
        $code = $_REQUEST["code"];
    }
    else
    {
        $_SESSION['state'] = md5(uniqid(rand(), TRUE)); //CSRF protection
        $dialog_url = "https://www.facebook.com/dialog/oauth?client_id=" 
        . $app_id . "&redirect_uri=" . urlencode($my_url) . "&state="
        . $_SESSION['state'];
        echo("<script> top.location.href='" . $dialog_url . "'</script>");
    }

    if ((isset($_REQUEST['state'])) && (($_REQUEST['state'] == $_SESSION['state'])))
    {
        $token_url = "https://graph.facebook.com/oauth/access_token?"
        . "client_id=" . $app_id . "&redirect_uri=" . urlencode($my_url)
        . "&client_secret=" . $app_secret . "&code=" . $code;

        $response = file_get_contents($token_url);
        $params = null;
        parse_str($response, $params);

        $graph_url = "https://graph.facebook.com/me?access_token=". $params['access_token'];

        $user = json_decode(file_get_contents($graph_url));
        if ( ! empty($user))
        {
                            // NO EMAIL HERE?!
            $email = strtolower($user->email);


        }
    }
4

2 に答える 2

2

以前にも質問されたようです。答えはここにあります:

Facebook Graph API、ユーザーのメールを取得する方法は?

于 2012-06-20T09:29:41.907 に答える
0

このコードは私にとってはうまくいきます...あなたにとってもうまくいくことを願っています

define('FACEBOOK_APP_ID', 'YOUR_APP_ID_HERE'); define('FACEBOOK_SECRET', 'YOUR_APP_SECRET_HERE');

        // No need to change function body
        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) {
            $response = parse_signed_request($_REQUEST['signed_request'],
                            FACEBOOK_SECRET);
            /*
            echo "<pre>";
            print_r($response);
            echo "</pre>"; // Uncomment this for printing the response Array
            */

            $email = $response["registration"]["email"];
于 2012-06-20T10:52:44.347 に答える