我使用以下代码发布到我的Facebook粉丝页面,它工作正常。现在我想使用cronjob发布到Facebook。我知道我必须使用访问令牌,但我不知道如何设置它。我尝试使用echo
我自己的访问令牌和页面的访问令牌,并在post api中使用它,但是没有用,我收到了这个错误:
Uncaught OAuthException: An active access token must be used to query information about the current user.
这是我尝试过的代码:
require_once('scripts/facebook.php');
$config = array('appId' => 'xxx','secret' => 'xxx');
$params = array('scope'=>'user_likes,publish_actions,email,offline_access,publish_stream,manage_pages');
$facebook = new Facebook($config);
$user = $facebook->getUser();
if($facebook->getUser()) {
try {
$user_profile = $facebook->api('/me');
$access_token = $facebook->getAccessToken();
//echo "1. ".$access_token;
} catch(FacebookApiException $e) {
$login_url = $facebook->getLoginUrl($params);
error_log($e->getType());
error_log($e->getMessage());
}
} else {
$login_url = $facebook->getLoginUrl($params);
}
$page_id = "xxxxxxxxxxxxx";
$page_access_token = "";
$result = $facebook->api("/me/accounts");
foreach($result["data"] as $page) {
if($page["id"] == $page_id) {
$page_access_token = $page["access_token"];
//echo '<br>';
//echo "2. ".$page_access_token;
break;
}
}
$args = array(
'access_token' => 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
'message' => stripslashes($image_caption).$animaged_gif,
'name' => stripslashes($image_caption).$animaged_gif,
'link' => "http://www.example.com/images.php?i=".$image_name,
'picture' => "http://www.example.com/thumbnails/".$image_name.".png",
'actions' => array(
'name' => 'See Pic',
'link' => "http://www.example.com/images.php?i=".$image_name
)
);
$post = $facebook->api("/$page_id/feed","post",$args);
正如您所看到的那样,我尝试使用当我回显自己的访问令牌时获得的实际访问令牌。但那没用。我还使用了页面的访问令牌,但这也没有用。你能告诉我这里缺少什么或者这样做的正确方法是什么?
在我做了一些进一步的搜索之后,我遇到了setAccessToken
和$page_info = $fb->api("/".$sInfo['pageId']."?fields=access_token");
但是关于如何使用它们的资源非常有限。我甚至不确定这些是否适合这个问题。我需要知道的是我需要使用哪个访问令牌以及设置它的适当代码是什么?
答案 0 :(得分:13)
这是你可以做到的:
我以为我会选择一个算法,而是添加所有可能的代码和文档,因为这可能会帮助其他人。
获取短期访问令牌并扩展它:
<强> fetchtoken.php 强>
<?php
//read more : https://developers.facebook.com/docs/howtos/login/server-side-login/
session_start();
$app_id = "xxxxxxxxxxxxxx";
$app_secret = "xxxxxxxxxxxxxxxx";
$my_url = "www.stackoverflow.com/"; // redirect url
$code = $_REQUEST["code"];
if(empty($code)) {
// Redirect to Login Dialog
$_SESSION['state'] = md5(uniqid(rand(), TRUE)); // CSRF protection
$dialog_url = "https://www.facebook.com/dialog/oauth?client_id="
. $app_id . "&redirect_uri=" . urlencode($my_url) . "&state="
. $_SESSION['state'] . "&scope=publish_stream,read_friendlists,email";
echo("<script> top.location.href='" . $dialog_url . "'</script>");
}
if($_SESSION['state'] && ($_SESSION['state'] === $_REQUEST['state'])) {
$token_url = "https://graph.facebook.com/oauth/access_token?"
. "client_id=" . $app_id . "&redirect_uri=" . urlencode($my_url)
. "&client_secret=" . $app_secret . "&code=" . $code;
$response = file_get_contents($token_url);
$params = null;
parse_str($response, $params);
$longtoken=$params['access_token'];
//save it to database
}
?>
因此,您现在可以在数据库,文本文件或其他任何内容中使用长期存在的accessstoken。
<强> cronjob.php 强>
<?
require_once('scripts/facebook.php');
// Pull access token from the file/db
$access_token = "access token from file or db";
$facebook->setAccessToken($access_token); // sets our access token as the access token when we call something using the SDK, which we are going to do now.
$config = array('appId' => 'xxx','secret' => 'xxx');
$params = array('scope'=>'user_likes,publish_actions,email,publish_stream,manage_pages');
$facebook = new Facebook($config);
$user = $facebook->getUser();
if($facebook->getUser()) {
try {
$user_profile = $facebook->api('/me');
} catch(FacebookApiException $e) {
$login_url = $facebook->getLoginUrl($params);
error_log($e->getType());
error_log($e->getMessage());
}
}
else {
$login_url = $facebook->getLoginUrl($params);
}
$page_id = "xxxxxxxxxxxxx";
$page_access_token = "";
$result = $facebook->api("/me/accounts");
foreach($result["data"] as $page) {
if($page["id"] == $page_id) {
$page_access_token = $page["access_token"];
//echo '<br>';
//echo "2. ".$page_access_token;
break;
}
}
$args = array(
'access_token' => $page_access_token,
'message' => stripslashes($image_caption).$animaged_gif,
'name' => stripslashes($image_caption).$animaged_gif,
'link' => "http://www.example.com/images.php?i=".$image_name,
'picture' => "http://www.example.com/thumbnails/".$image_name.".png",
'actions' => array(
'name' => 'See Pic',
'link' => "http://www.example.com/images.php?i=".$image_name
)
);
$post = $facebook->api("/$page_id/feed","post",$args);
?>
确保您不再在脚本中抓取access_token(用户访问令牌/ $ access_token)。
此外,作为页面访问令牌的access_token
中的$args
应该由$ page_access_token变量插入,而不是手动插入。
在示波器中使用offline_access
除了在权限对话框中显示它们之外,任何时候都可以访问它们的数据,无论如何都可以在没有该通知的情况下完成。
只要您在开始时访问fetch.php一次,并且每60天一次手动,这应该有效。
让我知道。
答案 1 :(得分:8)
这应该可以解决它。
不推荐使用offline_access 。它现在被一个系统所取代,你可以获得一个扩展的expiry access_token。
当您手动运行它时,您会生成一个实时访问令牌,该令牌在您实际运行后1-2小时后无效。并且你无法用cron生成另一个access_token。生成访问令牌应该手动完成。
要解决此问题,请阅读:https://developers.facebook.com/roadmap/offline-access-removal/
并实现此目的:https://developers.facebook.com/docs/howtos/login/server-side-login/
将Access令牌保存到数据库中。运行cron时,从数据库中获取令牌。
P.S:access_token有效期为60天,应该再次扩展,可以由用户手动登录完成。 access_token通常“可能”不会改变,但只会延长到期时间。
ADD:
安排帖子: 您也可以安排最多6个月的帖子。只是阅读它,并认为我会指出。
阅读:https://developers.facebook.com/docs/reference/api/page/向下滚动到帖子创建部分
答案 2 :(得分:0)
您可以取消Facebook API的全部开销,并遵循这种极其简单的方法。
在页面设置的“移动”部分(https://www.facebook.com/pages/edit/?id=INSERT_YOUR_PAGE_ID_HERE&sk=mobile)中查看您的特定于网页的电子邮件地址,然后在此处使用:
<?php
mail("thatEmailAddress@facebook.com", "New Status Update!", "");
?>
身体是空的,因为Facebook说“要更新你的状态,写入电子邮件主题行并将电子邮件正文留空。”
答案 3 :(得分:0)
你可以看看https://github.com/newbacknew/owloo.com。这是来自owloo.com的脚本基础,用于通过“ADS”仪表板从Facebook获取数据,还必须从Twitter和Instagram中检索分析数据。
使用基本脚本,您可以从Facebook获取每个国家,城市,舞台,粉丝页面的趋势,兴趣,行为,人口统计,年龄,性别数量
所有脚本的基础都在备份文件夹的WSERVICE文件夹中。