1

私は多くのグーグル検索を行ってきましたが、この問題に対する答えは見つかりませんでした。

Facebook JS SDK の実装については、Facebook のドキュメントに従っています。これが私のページのコードスニペットです

<script>
    window.fbAsyncInit = function() {
        FB.init({
            appId  : 'xxxxxxxxxxxxx',
            status : true, // check login status
            cookie : true, // enable cookies to allow the server to access the //session
            xfbml  : true, // parse XFBML
            oauth :true // Enable oauth 2.0
        });
        FB.Canvas.setAutoResize(); //set size according to iframe content size
    };

    // 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>

これは、1 つのファイルを除いて、かなりうまく機能します: http://static.ak.facebook.com/connect/canvas_proxy.php

all.jsは HTTPS 経由で正常に読み込まれます。ただし、Facebook は引き続き通常の HTTP 経由で canvas_proxy.php を読み込みます。

http://static.ak.facebook.com/connect/canvas_proxy.php?version=3#behavior=p&method=setSize¶ms=%7B%22height%22%3A714%2C%22width%22%3A1100%2C%22frame%22 %3A%22iframe_canvas%22%7D

どうしてこれなの?私はすべてを正しくやっているようです。その URL が原因で、HTTPS ユーザーが私のページにアクセスすると、セキュリティ警告がスローされます。

4

1 に答える 1

0

FB.initを呼び出す前に、FB._https=trueを設定してみてください。これにより、canvas_proxy.phpが処理されます。

安全でないアイテムをロードするHTTPSを介したFacebookJavaScriptSDKで最初に詳述されたソリューション

于 2012-02-13T20:43:15.970 に答える