Facebook登录链接自动刷新到Facebook用户个人资料链接和图片

时间:2012-01-03 13:31:21

标签: facebook wordpress login

我正在尝试使用Gravity Forms制作一个WordPress提交表单,其中访问者看到“使用Facebook登录”按钮。

一旦访问者登录并授予权限,该部分就会刷新以显示Facebook用户个人资料链接和图片,让访问者知道他们正在使用Facebook个人资料提交。

我已经复制了代码,但我需要一些帮助来完成它。

<div id="fb-root"></div>
<script>
  window.fbAsyncInit = function() {
    FB.init({
      appId      : 'XXXXXXXXXXXXXXXXX', // App ID
      channelUrl : '//www.MY-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
    });

    // Additional initialization code here
  };

  // Load the SDK Asynchronously
  (function(d){
     var js, id = 'facebook-jssdk'; if (d.getElementById(id)) {return;}
     js = d.createElement('script'); js.id = id; js.async = true;
     js.src = "//connect.facebook.net/en_US/all.js";
     d.getElementsByTagName('head')[0].appendChild(js);
   }(document));
</script>

<script>
  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
    }
  });
</script>

现在,我该怎么做才能获得可以显示“登录按钮”的部分,然后在有人登录后显示用户个人资料链接?

2 个答案:

答案 0 :(得分:0)

登录时,您可以使用以下方法之一:

答案 1 :(得分:0)

您在页面加载时调用API太早了。首先,需要在facebook脚本准备好运行之后完成。您可以将代码放入fbAsyncInit()函数中。其次,您应该遵循此范例以确保用户登录到您的应用,请参阅:https://developers.facebook.com/docs/reference/javascript/FB.getLoginStatus/