Facebook PHP SDK v.3.1.1-';必须使用活动访问令牌';关于简单例子

Facebook PHP SDK v.3.1.1-';必须使用活动访问令牌';关于简单例子,facebook,sdk,facebook-php-sdk,Facebook,Sdk,Facebook Php Sdk,我在实现最新的PHPSDK和OAuth2时遇到了一些大错误,因此我将其分解为使用提供的示例来演示我遇到的问题 我正在使用这个代码。我收到OAutheException“必须使用活动访问令牌查询当前用户的信息”。当我单击“使用Facebook登录”链接时,我继续收到此错误,并且我没有连接。请注意,当所有cookie和会话都已清除时,这通常会起作用,但如果我返回,则在几个小时后它将不再起作用 如果你能帮我,我将不胜感激 还请注意,这不在画布页面上 <?php ob_start(); /**

我在实现最新的PHPSDK和OAuth2时遇到了一些大错误,因此我将其分解为使用提供的示例来演示我遇到的问题

我正在使用这个代码。我收到OAutheException“必须使用活动访问令牌查询当前用户的信息”。当我单击“使用Facebook登录”链接时,我继续收到此错误,并且我没有连接。请注意,当所有cookie和会话都已清除时,这通常会起作用,但如果我返回,则在几个小时后它将不再起作用

如果你能帮我,我将不胜感激

还请注意,这不在画布页面上

<?php
ob_start();
/**
 * Copyright 2011 Facebook, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License"); you may
 * not use this file except in compliance with the License. You may obtain
 * a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
 * License for the specific language governing permissions and limitations
 * under the License.
 */

require_once('../facebook-php-sdk/facebook.php');

include('app3.conf.inc.php');

$facebook = new Facebook(array (
            'appId' => $appConf['appID'],
            'secret' => $appConf['appsecret'],
        ));

// Get User ID
$user = $facebook->getUser();

// We may or may not have this data based on whether the user is logged in.
//
// If we have a $user id here, it means we know the user is logged into
// Facebook, but we don't know if the access token is valid. An access
// token is invalid if the user logged out of Facebook.
if ($user) {
  try {
    // Proceed knowing you have a logged in user who's authenticated.
    $user_profile = $facebook->api('/me?fields=permissions');
  } catch (FacebookApiException $e) {
     error_log($e);
    $user = null;
  }
}


// Login or logout url will be needed depending on current user state.
if ($user) {
  $logoutUrl = $facebook->getLogoutUrl();
} else {
  $loginUrl = $facebook->getLoginUrl();
}

// This call will always work since we are fetching public data.
try
{
    $naitik = $facebook->api('/naitik');
}
catch (Exception $ex)
{
    echo("Exception with api/naitik:\n<pre>");
    var_dump($ex);
    echo("</pre>");
    die();
}

?>
<!doctype html>
<html xmlns:fb="http://www.facebook.com/2008/fbml">
  <head>
    <title>php-sdk</title>
    <style>
      body {
        font-family: 'Lucida Grande', Verdana, Arial, sans-serif;
      }
      h1 a {
        text-decoration: none;
        color: #3b5998;
      }
      h1 a:hover {
        text-decoration: underline;
      }
    </style>
  </head>
  <body>
    <h1>php-sdk</h1>

    <?php if ($user): ?>
      <a href="<?php echo $logoutUrl; ?>">Logout</a>
    <?php else: ?>
      <div>
        Login using OAuth 2.0 handled by the PHP SDK:
        <a href="<?php echo $loginUrl; ?>">Login with Facebook</a>
      </div>
    <?php endif ?>

    <h3>PHP Session</h3>
    <pre><?php print_r($_SESSION); ?></pre>

    <h3>Cookies</h3>
    <pre><?php print_r($_COOKIE); ?></pre>


    <?php if ($user): ?>
      <h3>You</h3>
      <img src="https://graph.facebook.com/<?php echo $user; ?>/picture">

      <h3>Your User Object (/me)</h3>
      <pre><?php print_r($user_profile); ?></pre>
    <?php else: ?>
      <strong><em>You are not Connected.</em></strong>
    <?php endif ?>

    <h3>Public profile of Naitik</h3>
    <img src="https://graph.facebook.com/naitik/picture">
    <?php echo $naitik['name']; ?>
  </body>
</html>

php sdk
身体{
字体系列:“Lucida Grande”,Verdana,Arial,无衬线;
}
H1A{
文字装饰:无;
颜色:#3b5998;
}
H1A:悬停{
文字装饰:下划线;
}
php sdk
使用PHP SDK处理的OAuth 2.0登录:
PHP会话
曲奇饼
你
/图片“>
您的用户对象(/me)
您没有连接。
奈提克的公众简介

看起来你很接近了。在facebook的php配置下面,我提供了一个if-GET查询来检测用户是否已注销。当他们注销时,条件中的代码将触发

unset($_COOKIE['fbsr.'.$config['appId']]);

而不是

unset($\u COOKIE['fbsr.'$this->getAppId()]);


这似乎很有魅力。

Facebook已经提出并接受了一个最新SDK的bug。我建议从2011年初到那时降到一个。它解决了我的问题。

cookies中有一个签名请求。当我解码它时,它大约有6个小时了。你的url中有代码吗?你需要使用代码获得access_token.Yes,单击Facebook链接登录后,URL中有一个代码。我开始转储SDK发出的每个API调用。第一个是to,它会导致字符串“{”error:{”message:“代码无效或过期。会话在unix时间1317819600过期。当前unix时间为1317836099。”,“type:“OAuthException”}”(length=158)它使用的是相同的旧代码,而不是URL中的代码。它似乎存储在某个位置,如cookie或会话。似乎有一个名为“fbsr_{appid}”(其中有真实的应用程序ID)的cookie其中包含一个已签名的请求,而该请求又包含一个“代码”。SDK使用的是此代码,而不是URL中给出的最新代码。我似乎已通过添加unset($\u COOKIE['fbsr'.$this->getAppId())将其修复;以清除所有PersistentData,并在给出代码时调用它。我现在对这个SDK没有信心。下面是我能够克服这个问题的方法:if(isset($\u GET['logoff']){//初始化会话。session_start();//取消设置所有会话变量。$\u session=array();//如果希望终止会话,还可以删除会话cookie。如果(ini_get(“session.use_cookies”){$params=session_get_cookie_params();setcookie(session_name(),'',time()-42000,$params[“path”],$params[“domain”],$params[“secure”],$params[“httponly”];//最后,销毁会话。}否则{//Get User ID$User=$facebook->getUser();}我认为您还需要销毁fbsr_appid cookie。我已降级到较旧的版本,并且没有问题。FB已接受一个错误。