私はこれと非常によく似たエラーを実行しています: Facebook Login API HTTPS Issue。
Facebook認証を使用するWebサイトがありますが、Facebookログインは問題ありません。しかし、Facebook のようなボタンをクリックすると問題が発生します (OSX の Chrome、Safari、Firefox でテストが失敗します)。エラー メッセージは次のとおりです。
Blocked a frame with origin "https://www.facebook.com" from accessing a
frame with origin "http://static.ak.facebook.com". The frame requesting
access has a protocol of "https", the frame being accessed has a protocol
of "http". Protocols must match.
私はすべてを検索しましたが、解決策が見つかりません。
いいねボタンをクリックすると、 https://facebook.comコールバックからフレームが飛び出し、http://static.ak.facebook.comをリクエストしようとすると、プロトコルの不一致が発生するようです?!
<body>
これが私がタグの直後に置いたものです
<div id="fb-root"></div>
<script>
window.fbAsyncInit = function() {
// init the FB JS SDK
FB.init({
appId : 'appid', // App ID from the app dashboard
channelUrl : '//mydomain/channel.html', // Channel file for x-domain comms
status : true, // Check Facebook Login status
xfbml : true // Look for social plugins on the page
});
// Additional initialization code such as adding Event Listeners goes here
};
// Load the SDK asynchronously
(function(d, s, id){
var js, fjs = d.getElementsByTagName(s)[0];
if (d.getElementById(id)) {return;}
js = d.createElement(s); js.id = id;
js.src = "//connect.facebook.net/zh_TW/all.js";
fjs.parentNode.insertBefore(js, fjs);
}(document, 'script', 'facebook-jssdk'));
</script>
およびチャンネルファイルhttp://mydomain/channel
<script src="//connect.facebook.net/zh_TW/all.js"></script>
そして、これが私がいいねボタンを使用する方法です
<div class="fb-like" data-href=url data-send="true" data-width="450"
data-show-faces="true"></div>
本当に助けが必要です、お願いします!