3

PHPSDKを使用してユーザーを承認するFacebookアプリケーションがあります。ほとんどの場合は機能しますが、機能しない場合もあり、その理由がわかりません。

以下のコードを使用しています。まず、ユーザーがいるかどうか、有効なトークンがあるかどうかを確認します(「/ me」をリクエストして)。もしそうなら、私は終了してアプリケーションを表示します。そうでない場合は、とのリンクを生成してgetLoginUrl()表示します。

それが機能しない場合、スクリプトはこのリンクを表示し続けます。エラーメッセージや、機能しない理由についての情報はありません。

変数を出力してみ$_GETたところ、FacebookがURLに「state」と「code」の2つのクエリパラメーターを追加していることがわかりました。誰かが彼らが何であるか知っていますか?

また、以下のスクリプトが機能しない理由はありますか?常に機能することを確認するためにチェックできるものはありますか?

$fb_ = new Facebook(array(
    'appId'  => 'appid',
    'secret' => 'secret',
)); 

$userId = $fb_->getUser();
$errorMessage = null;

if ($userId) {
    try {
        $user_ = $fb_->api('/me');
        if (isset($user_['error_code'])) {
            $errorMessage = isset($user_['error_msg']) ? self::$user_['error_msg'] : 'An unknown error occurred';
            $errorMessage .= ' (' . $user_['error_code'] . ')';
            $user_ = null;
        }
    } catch (FacebookApiException $e) {
        $errorMessage = $e->getMessage();
        $user_ = null;
    }
}

if ($user_) return;

$loginUrl = $fb_->getLoginUrl(array(
    'scope' => 'publish_stream,publish_actions'
));

echo '<!doctype html>';
echo '<html xmlns:fb="http://www.facebook.com/2008/fbml">';
echo '<head>';
echo '<title>' . t('Login to Facebook application') . '</title>';
echo '</head>';
echo '<body>';
if ($errorMessage) echo t('Error: %1', $errorMessage) . '<br/>';
echo t('Please login with Facebook first: %1', '<a href="' . $loginUrl . '">' . t('Login with Facebook') . '</a>');
echo '</body>';
echo '</html>';
die();

編集:

リクエストに応じて、oauthリクエストは次のとおりです。

Request URL:https://www.facebook.com/dialog/oauth?client_id=142896759165492&redirect_uri=http%3A%2F%2Fmxcclient.emarkethink.net%2Flogin&state=ebe253fa859a96e76332935901c32c&scope=publish_stream%2Cpublish_actions
Request Method:GET
Status Code:302 Found

そして私がFacebookから得た反応:

Cache-Control:private, no-cache, no-store, must-revalidate
Content-Length:0
Content-Type:text/html; charset=utf-8
Date:Tue, 17 Apr 2012 07:47:38 GMT
Expires:Sat, 01 Jan 2000 00:00:00 GMT
Location:http://mxcclient.emarkethink.net/login?state=ebe2785a859a96e76332935901c32c&code=AQAN-0ZXg_apegtybid642HOXbU2n5MNl8fYWcPGXiCoFyG7ogJpr53aKBaQKNKz-2wTtPQLpbJd8jAA1fkyw4Kw40Ssylc0b3kFrhnexGJgID8JX-pJEQvKC6wLYL93lQzrA6qFRnS2R6pd0dq-xGLy3YQ-6INC0vQyN_Qhi00M3oAo95b2IeBg4_11E#_=_
P3P:CP="Facebook does not have a P3P policy. Learn why here: http://fb.me/p3p"
Pragma:no-cache
Set-Cookie:locale=en_US; expires=Tue, 24-Apr-2012 07:47:38 GMT; path=/; domain=.facebook.com
X-Cnection:close
X-Content-Type-Options:nosniff
X-FB-Debug:Wnqw6loUBt4vRR21t7Btve/FPWWrfeoXDxhgiHA=
X-XSS-Protection:0
4

1 に答える 1

2

Okはついに問題が何であるかを知りました:

  • アプリケーションがiframeで実行され、P3ポリシーが設定されていないため、InternetExplorerでは機能しませんでした。

  • サードパーティのCookieがブロックされたため、Google Chromeでは機能しませんでした(iframeで実行されているアプリケーションは「サードパーティ」と見なされます)。

したがって、どちらの場合も、ログインは成功しましたが、認証トークンを保存できませんでした。つまり、次のリクエストは失敗しました。

于 2012-04-23T07:46:30.007 に答える