为什么我收到错误消息说我已经注销即使我的应用程序似乎工作正常?

时间:2011-09-19 10:19:53

标签: php facebook oauth facebook-authentication

我创建了一个简单的应用程序,目的是使用我个人网站上的PHP脚本发布到Facebook页面。

经过多次试验和错误,似乎工作得很好。我可以通过我的网站登录我的应用程序,发布内容,然后返回我的网站。所以一切都很好。

一个奇怪的是,尽管一切正常,我在日志中收到此错误:

  

OAuthException:验证访问令牌时出错:会话无效   因为用户退出了。

我用Google搜索了错误,从我看到的情况来看,大多数人都会遇到超时或意外退出。解决方案的范围包括如何维护登录会话。

但是,我认为我的情况与我见过的其他问题有所不同,因为尽管有错误,我似乎仍然登录。我可以根据需要多次发布到我的Page Wall。

每次发布​​到墙上时似乎都不会生成错误。它似乎每三到四个中出现一个,但它不一致,我无法确定模式。

由于一切正常,我可以忽略错误信息,但在我看来这是不好的做法。我以后不想偷偷咬我的东西。

非常感谢任何帮助或建议。


驱动Facebook交互的代码与我的CMS集成在一起,因此它的某些部分会散布,和/或可能因为我必须自定义的部分而模糊不清。但是,我相信这个功能有PHP的互动。如果这足以帮助确定问题的根源,请告诉我:

private function executeFacebookPost()
{
    // Facebook posts are limited to 420 characters. Links and pictures
    // are separate.
    $bodyOption = $this->mention->getOption(Action::$BODY);
    if (count($bodyOption) == 0)
    {
        $fbPost = '';
    }
    else
    {
        $fbPost = $bodyOption[1];
    }

    $linkOption = $this->mention->getOption(Action::$LINK_TO);
    if (count($linkOption) == 0)
    {
        $link = '';
    }
    else
    {
        $link = $linkOption[1];
    }
    // Use require_once() and not require() because you might be doing
    // some facebook action elsewhere, and this script will die a sad
    // death if it's asked to require more than once.
    require_once('+facebook/facebook.php');

    // Create our Application instance
    $facebook = new Facebook(array(
                'appId' => Site::getFacebookAppID(),
                'secret' => Site::getFacebookSecret(),
            ));
    $fbUser = $facebook->getUser();
    if ($fbUser)
    {
        try
        {
            $page_id = Site::getFacebookPage();
            $page_info = $facebook->api("/$page_id?fields=access_token");
            if (!empty($page_info['access_token']))
            {
                $args = array(
                    'access_token' => $page_info['access_token'],
                    'message' => $fbPost,
                    'link' => $link,
                        //'description' => "aaaaaaaasdfsfsdf",
                        //'picture' => "http://cdn1.kingdomsofcamelot.com/fb/e2/src/img/fte/army_troop.png",
                );
                $post_id = $facebook->api("/$page_id/feed", "post", $args);
            }
        }
        catch (FacebookApiException $e)
        {
            error_log($e, 1, 'ebisudave@gmail.com');
        }
    }
}

2 个答案:

答案 0 :(得分:5)

当您获得access_token时,请求offline_access然后您的令牌不会过期。

答案 1 :(得分:3)

在不访问代码的情况下无法提供帮助。 但我认为应用程序(来自手机,浏览器......)改变了当前令牌,试图从您的Facebook帐户获取更新。 注销此设备再次测试它。