facebook OAuthException:必须使用活动访问令牌来查询有关当前用户的信息

时间:2012-09-28 10:47:26

标签: php codeigniter facebook-php-sdk

facebook Uncaught OAuthException: An active access token must be used to query information about the current user

可能重复

但我没有得到适当的解决方案。

我正在使用facebook sdk和codeigniter它正常工作。但有时它会抛出异常OAuthException:必须使用活动访问令牌来查询有关当前用户的信息。

以下是Controller文件的代码

$config = array(
                    'appId'  => 'XXXXXXX',
                    'secret' => 'XXXXXXXXXXXXXXXXXXXXXXXXXX',
                    'fileUpload' => true,
              );

$this->load->library('facebook/Facebook', $config);

$fbme = null;

$user = $this->facebook->getUser();

if ($user) {
    try {               
        $fbme = $this->facebook->api('/me');
    } catch (FacebookApiException $e) {
          error_log($e);
          $user = null;
    }
}

//if user is logged in and session is valid.
if ($fbme){
              //do some stuff...
              //redirecting to user home page (my site's)
    }

在视图文件中,我使用的是js sdk。视图文件的代码是

<div id="fb-root"></div>
    <script type="text/javascript">
        var button2;

        window.fbAsyncInit = function() {
            FB.init({ appId: 'XXXXXXXX',
                status: true,
                cookie: true,
                xfbml: true,
                oauth: true});

           function updateButton(response) {
                button1 = document.getElementById('fb-login'); //login button
                button2 = document.getElementById('fb-logout'); //logout button
                if (response.authResponse) {
                    //user is already logged in and connected
                                button2.onclick = function() {
                                    FB.logout(function(response) {});
                                };
            } else {
                    //user is not connected to your app or logged out
                    button1.onclick = function() {
                        FB.login(function(response) {
                            if (response.authResponse) {
                            } else {
                                //user cancelled login or did not grant authorization
                            }
                        }, {scope:'email,user_birthday,user_about_me,user_likes,user_interests,user_education_history,user_work_history'});
                    }
                }
            }

            // run once with current status and whenever the status changes
            FB.getLoginStatus(updateButton);
            FB.Event.subscribe('auth.login', function(response) {
                window.location.reload();
            });
            FB.Event.subscribe('auth.logout', function(response) {
                window.location.reload();
            });
        };
        (function() {
            var e = document.createElement('script'); e.async = true;
            e.src = document.location.protocol
                + '//connect.facebook.net/en_US/all.js';
            document.getElementById('fb-root').appendChild(e);
        }());       
    </script>

问题:

有时它会抛出“OAuthException:必须使用活动访问令牌来查询有关当前用户的信息。”到错误日志文件。

案例:用户已登录Facebook,并且已对我的应用进行了身份验证 如果用户登录Facebook并验证我的应用程序并尝试登录到我的网站, 而是将用户重定向到我的站点(在这种情况下php sdk不工作),它正在加载视图文件。在视图文件中,我也在检查用户是否登录了facebook。 (在视图中)如果用户登录将重新加载页面,将运行相同的控制器脚本,并将用户重定向到用户的主页(在这种情况下,php sdk正在运行。)。

但第一次它不起作用。不知道我在哪里弄错了。

此外,该注销按钮(在视图文件中)有时也无法正常工作。单击它的方法不是从Facebook注销用户。 (这只发生在我同事的一个浏览器中。她在Windows 7中使用chrome)

1 个答案:

答案 0 :(得分:5)

我在使用PHP-SDK + JS-SDK时遇到了类似的问题。我通过删除FB.init “cookie:true”选项暂时解决了这个问题。

由于某些原因我无法找到,PHP和JS之间正在共享一个无效的 signedRequest cookie,因此PHP会话的有效access_token被覆盖了无效的access_token,因此,销毁以前有效的PHP令牌。

我和你的问题之间的区别在于你是通过JS登录并尝试在PHP上访问同一个会话(我正在向后执行,登录PHP并尝试使用JS-SDK)。

此错误显然已在此拉取请求中修复: https://github.com/facebook/facebook-php-sdk/pull/48