Javascript没有在Facebook上运行iframe

时间:2013-12-19 18:10:10

标签: javascript facebook iframe facebook-javascript-sdk facebook-iframe

我有一个django项目,适用于facebook应用程序。在项目中,邀请朋友模块在localhost中运行良好!

Runs fine on localhost

但是当它在facebook应用程序中加载时,负责显示好友列表的javascript无法正常工作。虽然库已正确加载。

Javascript doesnot run on facebook app

我不知道为什么会这样。可能是一些iframe问题。 以下是javascript代码

<script type="text/javascript"> 
window.fbAsyncInit = function() {
    FB.init({appId: '460948667348013', cookie: true});

    FB.getLoginStatus(function(response) {
      if (response.status === 'connected') {
         FB.api('/me', function(response) {
           // alert('Your name is ' + response.name);
           console.log('Your name is ' + response.name);
          init();
         });
      } else if (response.status === 'not_authorized') {
        alert('the user is logged in to Facebook, but has not authenticated your app');
      } else {
        alert('the user is not logged in to Facebook.');
      }
     });  
}
    function init() {
      FB.api('/me', function(response) {
          $("#username").html("<img src='https://graph.facebook.com/" + response.id + "/picture'/><div>" + response.name + "</div>");       
          $("#jfmfs-container").jfmfs({ 
              max_selected: 15, 
              max_selected_message: "{0} of {1} selected",
              friend_fields: "id,name,last_name",
              pre_selected_friends: [1014025367],
              exclude_friends: [1211122344, 610526078],
              sorter: function(a, b) {
                var x = a.last_name.toLowerCase();
                var y = b.last_name.toLowerCase();
                return ((x < y) ? -1 : ((x > y) ? 1 : 0));
              }
          });
          $("#jfmfs-container").bind("jfmfs.friendload.finished", function() { 
              window.console && console.log("finished loading!"); 
          });
          $("#jfmfs-container").bind("jfmfs.selection.changed", function(e, data) { 
              window.console && console.log("changed", data);
          });                     

          $("#logged-out-status").hide();
          $("#show-friends").show();
      });
    }              

    $("#show-friends").live("click", function() {
        var friendSelector = $("#jfmfs-container").data('jfmfs');             
        $("#selected-friends").html(friendSelector.getSelectedIds().join(', ')); 
    });                  
    function sendRequest() {
       var friendSelector = $("#jfmfs-container").data('jfmfs');
       var sendUIDs = friendSelector.getSelectedIds().join(', '); 
       // Use FB.ui to send the Request(s)
       FB.ui({method: 'apprequests',
         to: sendUIDs,
         title: 'My Great Invite',
         message: 'Check out this Awesome App!',
       }, callback);
     }
     function callback(response) {
        // alert('callback called');
       var friendSelector = $("#jfmfs-container").data('jfmfs');
       var sendUIDs = friendSelector.getSelectedIds().join(','); 
       var uids = sendUIDs.split(',');
       var query = '';
       for(i=0;i<uids.length;i++){
        if(i==0){
            query =  query + 'to[' + i + ']=' + uids[i];
        }
        else{
        query =  query + '&to[' + i + ']=' + uids[i];
        }
       }
       console.log(query);
       if(response){
        // alert('successful');
        window.location.assign("/?"+ query)
       }
       else{
        alert('failure');
       }

     }

  </script> 

请帮忙!我遇到了这个问题。

1 个答案:

答案 0 :(得分:1)

问题可能是SSL问题。

Facebook在几个月前做了很多改变。

此外,您还需要与Facebook开发人员博客保持更新。

因此,我将尝试解释一些我怀疑的事情。

Facebook上的应用

  1. 您的画布页面应为https://apps.facebook.com/yourchoosenname
  2. 1a上。您的画布网址应为https://yoursite.com/yourapplication/

    网站

    http://yoursite.com/

    页面标签

    1. 安全画布应为https://yoursite.com/yourapplication/

    2. 网页标签网址应为https://yoursite.com/yourapplication/

    3. 安全网页标签网址应为https://yoursite.com/yourapplication/

    4. 在这种情况下,您需要网站的SSL证书,以便您可以从Here找到可靠但廉价的数字证书。

      这对于在Facebook上运行的任何应用程序都是强制性的。

      希望这会对你和其他人有所帮助