我的问题是显示一个登录按钮并(一旦用户登录)显示他的个人资料图像、名称和“注销”链接。
在 facebook api 文档(这里http://developers.facebook.com/docs/guides/web/#login)我找到了这个例子:
<html>
<head>
<title>My Facebook Login Page</title>
</head>
<body>
<div id="fb-root"></div>
<script>
window.fbAsyncInit = function() {
FB.init({
appId : 'YOUR_APP_ID', // App ID
channelUrl : '//WWW.YOUR_DOMAIN.COM/channel.html', // Channel File
status : true, // check login status
cookie : true, // enable cookies to allow the server to access the session
xfbml : true // parse XFBML
});
FB.api('/me', function(user) {
if (user) {
var image = document.getElementById('image');
image.src = 'http://graph.facebook.com/' + user.id + '/picture';
var name = document.getElementById('name');
name.innerHTML = user.name
}
});
};
// Load the SDK Asynchronously
(function(d){
var js, id = 'facebook-jssdk', ref = d.getElementsByTagName('script')[0];
if (d.getElementById(id)) {return;}
js = d.createElement('script'); js.id = id; js.async = true;
js.src = "//connect.facebook.net/en_US/all.js";
ref.parentNode.insertBefore(js, ref);
}(document));
</script>
<div align="center">
<img id="image"/>
<div id="name"></div>
</div>
</body>
</html>
那应该做我正在寻找的。我用我的 app_id 和我的域站点 (http://localhost/index.html) 替换了 'MY_APP_ID' 和 MY_DOMAIN.COM。我还添加了一个登录按钮,正如我在文档中找到的那样(有效并允许我登录),但没有显示图像或名称。我在控制台中编写了“用户”对象,它包含以下内容:
error: Object
code: 2500
message: "An active access token must be used to query information about the current user."
type: "OAuthException"
我应该如何使用这个“主动访问令牌”?