2
페이지에 게시물을 페이지로 추가하는 데 문제가 있습니다. 나는 다음과 같은 코드를 사용합니다SDK : 페이지에 페이지로 게시
$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.");
}
포스트가 올바르게 내 페이지에 추가되는하지만 포스트 내 페이지 계정으로 내 사용자 계정으로 추가되지 중입니다. 페이지로 게시하려면 어떻게해야합니까? 아니면 가능하지 않습니까?
해결 방법 : 난 당신이 페이지 access_token
를 사용해야하는 동안 사용자의 access_token
를 사용하는 코드
$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;
}
}
들으 응용 프로그램에 사용자가
manage_pages
권한을 부여하면이
은user
의accounts
연결에서 그래프 API를 통해 얻을 수 있습니다. –