关于 facebook graph api 的一个小问题。我一直在使用官方的Facebook Graph API PHP SDK。
我还在我的网页上包含了 facebook 社交评论插件小部件。是否可以使用 facebook 的 Graph api 在网页上发表评论?
用户将使用 facebook 登录到我的 Web 应用程序,然后他必须能够通过 API 在我的应用程序的网页上发布 facebook 评论。因此,小部件将显示所有直接发布在页面上的评论,以及通过 API 发布的评论。
到目前为止,我已经尝试过这个 AJAX 代码:
<?php
$token = $facebook->getAccessToken();
?>
<script src="//ajax.googleapis.com/ajax/libs/jquery/1.8.0/jquery.min.js"
type="text/javascript"></script>
<script type="text/javascript">
$.post('https://graph.facebook.com/comments/?ids=http://mywebsite.com/comments.php?id=123',{ name: 'John', message: 'Testing comments', 'method': 'POST', 'format': 'json', 'access_token': '<?php echo $token; ?>'},
function(data) {
});
</script>
但这是返回一个 OAUTH 异常:
{
"error": {
"message": "An unknown error has occurred.",
"type": "OAuthException",
"code": 1
}
}
我在设置登录 url 时请求足够的权限:
$loginUrl = $facebook->getLoginUrl(array(
'scope' => 'email,publish_stream,publish_actions,read_stream,user_about_me,user_events,create_event'
));
注意: 我在我的页面上包含了 facebook 小部件,使用以下代码:
<div class="fb-comments" data-href="http://www.mywebsite.com/comments.php?
id=<?php echo $_GET['id']; ?>" data-width="370" data-num-posts="5"></div>
脚本:
<div id="fb-root"></div>
<script>(function(d, s, id) {
var js, fjs = d.getElementsByTagName(s)[0];
if (d.getElementById(id)) return;
js = d.createElement(s); js.id = id;
js.src = "//connect.facebook.net/en_US/all.js#xfbml=1&appId=xxxxxxxxxxxxxxx";
fjs.parentNode.insertBefore(js, fjs);
}(document, 'script', 'facebook-jssdk'));</script>
<div id='fb-root'></div>
<script src='http://connect.facebook.net/en_US/all.js'></script>
<!--<p><a onclick='postToFeed(); return false;'>Post to Feed</a></p>-->
<p id='msg'></p>
<script>
FB.init({appId: "xxxxxxxxxxxxxxx", status: true, cookie: true});
function postToFeed() {
// calling the API ...
var obj = {
method: 'feed',
redirect_uri: 'http://www.mywebsite.com/comments.php?id=<?php echo $_GET['id']; ?>',
link: 'https://developers.facebook.com/docs/reference/dialogs/',
picture: 'http://fbrell.com/f8.jpg',
name: 'Facebook Dialogs',
caption: 'Reference Documentation',
description: 'Using Dialogs to interact with users.'
};
function callback(response) {
document.getElementById('msg').innerHTML = "Post ID: " + response['post_id'];
}
FB.ui(obj, callback);
}
</script>