Web サイトで OAuth プロセスに janrain ウィジェットを使用しています。次の URL でこれをテストしています: http://vignesh.gvignesh.org/register/
登録ボタンをクリックすると、ユーザーは Google、Yahoo、または Facebook からサインインします。トークンを取得して変数に格納できます。テストのために自分のサイトにトークンを表示しています。取得しているトークンからユーザー情報を抽出する方法がわかりません。
Web サイトで OAuth プロセスに janrain ウィジェットを使用しています。次の URL でこれをテストしています: http://vignesh.gvignesh.org/register/
登録ボタンをクリックすると、ユーザーは Google、Yahoo、または Facebook からサインインします。トークンを取得して変数に格納できます。テストのために自分のサイトにトークンを表示しています。取得しているトークンからユーザー情報を抽出する方法がわかりません。
<?php
$rpxApiKey = 'YOUR_API_KEY_HERE';
if(isset($_POST['token'])) {
  /* STEP 1: Extract token POST parameter */
  $token = $_POST['token'];
  /* STEP 2: Use the token to make the auth_info API call */
  $post_data = array('token' => $_POST['token'],
                     'apiKey' => $rpxApiKey,
                     'format' => 'json');
  $curl = curl_init();
  curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
  curl_setopt($curl, CURLOPT_URL, 'https://rpxnow.com/api/v2/auth_info');
  curl_setopt($curl, CURLOPT_POST, true);
  curl_setopt($curl, CURLOPT_POSTFIELDS, $post_data);
  curl_setopt($curl, CURLOPT_HEADER, false);
  curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
  $raw_json = curl_exec($curl);
  curl_close($curl);
  /* STEP 3: Parse the JSON auth_info response */
  $auth_info = json_decode($raw_json, true);
  if ($auth_info['stat'] == 'ok') {
    /* STEP 3 Continued: Extract the 'identifier' from the response */
    $profile = $auth_info['profile'];
    $identifier = $profile['identifier'];
    if (isset($profile['photo'])) {
      $photo_url = $profile['photo'];
    }
    if (isset($profile['displayName'])) {
      $name = $profile['displayName'];
    }
    if (isset($profile['email'])) {
      $email = $profile['email'];
    }
    print $identifier;
        echo "</br>";
    print $photo_url;
        echo "</br>";
    print $name;
        echo "</br>";
    print $email;
    /* STEP 4: Use the identifier as the unique key to sign the user into your system.
This will depend on your website implementation, and you should add your own
code here.
*/
/* an error occurred */
} else {
  // gracefully handle the error. Hook this into your native error handling system.
  echo 'An error occured: ' . $auth_info['err']['msg'];
}
}
?>
これにより、認証後に取得したトークンから情報が抽出されます。