我在页面上添加帖子作为页面时遇到问题。 我使用以下代码:
$app_id = "xxx";
$app_secret = "xxx";
$my_url = base_url().'admin/facebook/';
if(isset($_GET["code"])) {
$code = $_GET["code"];
} else {
$code = '';
}
if(empty($code)) {
$_SESSION['state'] = md5(uniqid(rand(), TRUE)); //CSRF protection
$dialog_url = "http://www.facebook.com/dialog/oauth?client_id="
. $app_id . "&redirect_uri=" . urlencode($my_url) . "&scope=manage_pages,publish_stream,offline_access&state="
. $_SESSION['state'];
echo("<script> top.location.href='" . $dialog_url . "'</script>");
}
if($_GET['state'] == $_GET['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);
$graph_url = "https://graph.facebook.com/me?access_token=".$params['access_token'];
$user = json_decode(file_get_contents($graph_url));
echo("Hello " . $user->name);
$pageID = '212154388861617';
// post to wall (feed is wall post, just update to whatever you want to publish to)
try {
//153406078098666
$publishStream = $this->fb_ignited->api("212154388861617/feed", 'post', array(
'message' => "Test message",
'access_token' => $params['access_token']
)
);
} catch (FacebookApiException $e) {
die($e);
}
}
else {
echo("The state does not match. You may be a victim of CSRF.");
}
该帖子已在我的网页上正确添加,但该帖子已添加为我的用户帐户,而不是我的网页帐户。 我如何发布为一个页面? 或者这不可能吗?
解决方案:我添加了这段代码
$result = $this->fb_ignited->api("/me/accounts", array('access_token' => $params['access_token']));
foreach($result["data"] as $page) {
if($page["id"] == $pageID) {
$page_access_token = $page["access_token"];
break;
}
}
答案 0 :(得分:1)
您需要使用页面access_token
时才能使用用户的access_token
。
一旦用户向您的应用授予accounts
权限,就可以通过manage_pages
{{1}}的{{1}}连接通过图谱API获取此内容