我正在使用以下代码发布到我的 Facebook 粉丝页面,并且运行良好。现在我想使用 cronjob 来发布到 Facebook。我知道我必须用作访问 token ,但我不确定如何设置它。我尝试使用 echo
我自己的访问 token 和页面的访问 token ,并在 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);
如您所见,我尝试使用在回显我自己的访问 token 时获得的实际访问 token 。但这没有用。我还使用了页面的访问 token ,但这也没有用。你能告诉我这里缺少什么或者正确的方法是什么吗?
经过进一步搜索后,我遇到了 setAccessToken
和 $page_info = $fb->api("/".$sInfo['pageId']."?fields=access_token") ;
但是关于如何使用它们的资源非常有限。我什至不确定这些是否适合这个问题。我只需要知道我需要使用哪个访问 token 以及设置它的适当代码是什么?
最佳答案
这是你可以做到的:
- 获取一个短期访问 token 。
- 扩展它。
- 获取长期存在的页面访问 token 。 (没关系,这里我们每次都会获取新的 accesstoken。不那么复杂,而且可靠。)
本以为我会使用算法,但我添加了所有可能的代码和文档,因为这也可能对其他人有所帮助。
获取短期访问 token 并扩展它:
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
}
?>
因此,您现在已经在数据库、文本文件或其他任何文件中准备了一个长期存在的访问 token 。
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(user access token/$access_token)。
此外,$args
中的 access_token
是页面访问 token ,应该由 $page_access_token 变量插入,而不是手动插入。
范围内的 offline_access
只是在权限对话框中向他们显示他们的数据可以随时访问,而无需通知即可完成。
只要您在开始时访问 fetch.php 一次,并且每 60 天手动访问一次,这应该会起作用。
让我知道。
关于php - Facebook PHP 使用 cronjob 发布到粉丝页面?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13217564/