无法理解Facebook未捕获的例外

时间:2016-08-13 23:11:57

标签: php facebook-graph-api facebook-php-sdk batch-processing

我是Facebook PHP SDK的新手。我无法理解下面的堆栈跟踪;我应该在哪里寻找错误?

Facebook预定的帖子已成功处理,但是,此错误会导致糟糕的用户体验,但是,我的程序中的其他所有内容都正常运行。看起来它可能正试图处理那些不存在的东西。

正在执行的最后一行代码(我知道因为预定的帖子显示在我的Facebook测试帐户中)是:

$responses = $fb->sendBatchRequest(($batch), $this->session->userdata('fb_access_token'));

$ batch定义为:

foreach($esdarr as $key => $event_start_datetime){$sched_time = strtotime($event_start_datetime)- 18000;
    $event_end_datetime = $eedarr[$key];
    $requestScheduleEvent = $fb->post('/'.$band_page_id.'/feed', ['message' => $band_name.' is playing today at '.$venue_name.' '.date('(l), g:ia', strtotime($event_start_datetime)), 'published'=>false, 'scheduled_publish_time'=>$sched_time], $pageToken);
    $batch[$key]=$requestScheduleEvent;
    }

这都在具有公共功能add()的CI控制器(event.php)中。然后我收到了这个错误:

 Fatal error: Uncaught exception 'InvalidArgumentException' with message 'Argument for add() must be of type array or FacebookRequest.' in /home/my_user/public_html/development/application/vendor/facebook/php-sdk-v4/src/Facebook/FacebookBatchRequest.php:85 Stack trace: 
#0 /home/my_user/public_html/development/application/vendor/facebook/php-sdk-v4/src/Facebook/FacebookBatchRequest.php(78): Facebook\FacebookBatchRequest->add(Object(Facebook\FacebookResponse), 0) 
#1 /home/my_user/public_html/development/application/vendor/facebook/php-sdk-v4/src/Facebook/FacebookBatchRequest.php(61): Facebook\FacebookBatchRequest->add(Array) 
#2 /home/my_user/public_html/development/application/vendor/facebook/php-sdk-v4/src/Facebook/Facebook.php(492): Facebook\FacebookBatchRequest->__construct(Object(Facebook\FacebookApp), Array, 'EAAYzEGW0ZAsoBA...', 'v2.7') 
#3 /home/my_user/public_html/development/application/controllers/user/event.php(777): Facebook\Facebook->sendBatchRequest(Array, 'EAAYzEGW0ZAsoBA...') 
#4 [internal function]: Event->add in /home/my_user/public_html/development/application/vendor/facebook/php-sdk-v4/src/Facebook/FacebookBatchRequest.php on line 85

如果按照以下方式更改FacebookBatchRequest.php的第85行(即将页面重定向到CI结构中的正确URL),一切似乎都可以正常工作:

 public function add($request, $name = null)
{
    if (is_array($request)) {
        foreach ($request as $key => $req) {
            $this->add($req, $key);
        }

        return $this;
    }

    if (!$request instanceof FacebookRequest) {
        ***redirect('user/event');***
        throw new \InvalidArgumentException('Argument for add() must be of type array or FacebookRequest.');
    }

    $this->addFallbackDefaults($request);
    $requestToAdd = [
        'name' => $name,
        'request' => $request,
    ];

当然,这是一个简单的解决方法。因此,我想知道为什么首先会抛出错误。

2 个答案:

答案 0 :(得分:0)

如果您在程序中定义了add()并且SDK中内置了add(),那么它将无法正常工作。尝试使用其他名称。

如果这不是问题,您能否发布您的代码?也许我们中的一个人可以找到它。

你用的是什么语言?也许你只是有语法错误。

我希望这有任何帮助!

答案 1 :(得分:0)

好的,这最终导致我错误地使用了批处理过程。

$requestScheduleEvent = $fb->post('/'.$band_page_id.'/feed', ['message' => $band_name.' is playing today at '.$venue_name.' '.date('(l), g:ia', strtotime($event_start_datetime)), 'published'=>false, 'scheduled_publish_time'=>$sched_time], $pageToken);

需要使用请求方法:

$batch[$key] = $fb->request('POST', '/'.$band_page_id.'/feed', ['message' => $band_name.' is playing today at '.$venue_name.' '.date('(l), g:ia', strtotime($event_start_datetime)), 'published'=>false, 'scheduled_publish_time'=>$sched_time], $pageToken);