1

我一直在开发一个使用 Facebook 的 API 来创建 Instant Articles 的 WordPress 插件。(我在这里使用 SDK 版本 5.3.1:https ://github.com/facebook/php-graph-sdk/tree/5.4 )它需要包含许多自定义字段,因此新插件而不是使用现有的。我使用 Vagrant/VirtualBox linux 服务器在本地机器上开发了它,从那里我能够成功地验证并创建一篇 Instant Article,然后它出现在 Facebook 的发布工具 > Instant Articles > Development Articles 的列表中。

我将相同的代码部署到实时 Web 服务器以继续对其进行测试。身份验证仍然成功,但是当我尝试从该服务器发布文章时,即时文章永远不会创建,也不会出现在 Facebook 的列表中。

令人费解的是,两次尝试的反应似乎几乎相同。一个区别是accessToken值,我已将其标记为{access_token}. 我标记为的回复之间的其他差异{different}

谁能帮我理解为什么一个成功而另一个失败,而 PHP 或 API 响应中没有任何明显的错误?

使用本地机器响应(成功):

object(Facebook\FacebookResponse)#144 (6) {
  ["httpStatusCode":protected]=>
  int(200)
  ["headers":protected]=>
  array(13) {
    ["Access-Control-Allow-Origin"]=>
    string(1) "*"
    ["Pragma"]=>
    string(8) "no-cache"
    ["Cache-Control"]=>
    string(44) "private, no-cache, no-store, must-revalidate"
    ["facebook-api-version"]=>
    string(4) "v2.7"
    ["Expires"]=>
    string(29) "Sat, 01 Jan 2000 00:00:00 GMT"
    ["Content-Type"]=>
    string(31) "application/json; charset=UTF-8"
    ["x-fb-trace-id"]=>
    string(11) "{different}"
    ["x-fb-rev"]=>
    string(7) "{different}"
    ["Vary"]=>
    string(15) "Accept-Encoding"
    ["X-FB-Debug"]=>
    string(88) "{different}"
    ["Date"]=>
    string(29) "Wed, 19 Oct 2016 16:24:51 GMT"
    ["Connection"]=>
    string(10) "keep-alive"
    ["Content-Length"]=>
    string(2) "25"
  }
  ["body":protected]=>
  string(25) "{"id":"{different}"}"
  ["decodedBody":protected]=>
  array(1) {
    ["id"]=>
    string(16) "{different}"
  }
  ["request":protected]=>
  object(Facebook\FacebookRequest)#145 (9) {
    ["app":protected]=>
    object(Facebook\FacebookApp)#183 (2) {
      ["id":protected]=>
      string(16) "{app_id}"
      ["secret":protected]=>
      string(32) "{app_secret}"
    }
    ["accessToken":protected]=>
    string(168) "{access_token}"
    ["method":protected]=>
    string(4) "POST"
    ["endpoint":protected]=>
    string(29) "/{some_endpoint_id}/instant_articles"
    ["headers":protected]=>
    array(1) {
      ["Content-Type"]=>
      string(33) "application/x-www-form-urlencoded"
    }
    ["params":protected]=>
    array(3) {
      ["development_mode"]=>
      string(1) "1"
      ["published"]=>
      bool(false)
      ["html_source"]=>
      string(1600) "<html> ... </html>"
    }
    ["files":protected]=>
    array(0) {
    }
    ["eTag":protected]=>
    NULL
    ["graphVersion":protected]=>
    string(4) "v2.7"
  }
  ["thrownException":protected]=>
  NULL
}

使用 Live Server 响应(失败):

object(Facebook\FacebookResponse)#107 (6) {
  ["httpStatusCode":protected]=>
  int(200)
  ["headers":protected]=>
  array(13) {
    ["Access-Control-Allow-Origin"]=>
    string(1) "*"
    ["Pragma"]=>
    string(8) "no-cache"
    ["Cache-Control"]=>
    string(44) "private, no-cache, no-store, must-revalidate"
    ["facebook-api-version"]=>
    string(4) "v2.7"
    ["Expires"]=>
    string(29) "Sat, 01 Jan 2000 00:00:00 GMT"
    ["Content-Type"]=>
    string(31) "application/json; charset=UTF-8"
    ["x-fb-trace-id"]=>
    string(11) "{different}"
    ["x-fb-rev"]=>
    string(7) "{different}"
    ["Vary"]=>
    string(15) "Accept-Encoding"
    ["X-FB-Debug"]=>
    string(88) "{different}"
    ["Date"]=>
    string(29) "Wed, 19 Oct 2016 16:02:08 GMT"
    ["Connection"]=>
    string(10) "keep-alive"
    ["Content-Length"]=>
    string(2) "24"
  }
  ["body":protected]=>
  string(24) "{"id":"{different}"}"
  ["decodedBody":protected]=>
  array(1) {
    ["id"]=>
    string(15) "{different}"
  }
  ["request":protected]=>
  object(Facebook\FacebookRequest)#106 (9) {
    ["app":protected]=>
    object(Facebook\FacebookApp)#126 (2) {
      ["id":protected]=>
      string(16) "{app_id}"
      ["secret":protected]=>
      string(32) "{app_secret}"
    }
    ["accessToken":protected]=>
    string(164) "{access_token}"
    ["method":protected]=>
    string(4) "POST"
    ["endpoint":protected]=>
    string(29) "/{some_endpoint_id}/instant_articles"
    ["headers":protected]=>
    array(1) {
      ["Content-Type"]=>
      string(33) "application/x-www-form-urlencoded"
    }
    ["params":protected]=>
    array(3) {
      ["development_mode"]=>
      string(1) "1"
      ["published"]=>
      bool(false)
      ["html_source"]=>
      string(1639) "<html> ... </html>"
    }
    ["files":protected]=>
    array(0) {
    }
    ["eTag":protected]=>
    NULL
    ["graphVersion":protected]=>
    string(4) "v2.7"
  }
  ["thrownException":protected]=>
  NULL
}
4

1 回答 1

1

感谢CBroe在他的评论中的建议,我能够发现问题的原因。在请求获取文章导入状态后,我在响应中发现了这个错误消息:

["body":protected]=>
  string(439) "{"errors":[{"level":"ERROR","message":"Unclaimed URL: The URL http:\/\/www.example.com\/my-article-url\/ has not been claimed for Instant Articles. Please check to make sure you have a URL registered for your page. For more information refer to URLs in the Publishing Articles section of the Instant Articles documentation."}],"status":"FAILED","id":"{some_id}"}"

然后我意识到,在构建 Instant Article 标记的函数中,我正在str_replace对标记进行操作,以便将我的本地测试域名替换为正确的“已声明”域名。由于我们已将代码部署到新域,因此没有发生这种替换,并且 Facebook 在标记中看到了不正确的“无人认领”域。

通过将新域名添加到要替换的名称数组中,我能够将标记发送到具有“已声明”域的 Instant Articles。我的文章创建成功!

非常感谢CBroe,我疯了。

于 2016-10-19T22:26:33.403 回答