繁体   English   中英

Javascript未在Facebook iframe上运行

[英]Javascript not running on Facebook iframe

我有一个专为Facebook应用程序设计的django项目。 在项目中,“邀请朋友”模块在localhost中运行良好!

在本地主机上运行良好

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

JavaScript无法在Facebook应用上运行

我不知道为什么会这样。 可能是一些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> 

请帮忙 ! 我陷入这个问题。

该问题可能是SSL问题。

Facebook在几个月前已进行了许多更改。

另外,您需要与Facebook开发人员博客保持最新。

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

Facebook上的应用

  1. 您的画布页面应为https://apps.facebook.com/yourchoosenname

1A。 您的Canvas URL应该是https://yoursite.com/yourapplication/

网站

http://yoursite.com/

页面标签

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

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

  3. 您的“ 安全页面”标签URL应为https://yoursite.com/yourapplication/

在这种情况下,您将需要站点SSL证书,因此您可以从Here找到可靠而便宜的数字证书。

这对于任何在Facebook上运行的应用程序都是必需的。

希望这对您和其他人有帮助

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM