我想我会发疯的。我无法让它发挥作用
我只是想在iFrame
应用中检查用户是否喜欢使用javascript的网页。
FB.api({
method: "pages.isFan",
page_id: my_page_id,
}, function(response) {
console.log(response);
if(response){
alert('You Likey');
} else {
alert('You not Likey :(');
}
}
);
返回:False
但我是我的页面的粉丝,所以不应该返回真的吗?!
答案 0 :(得分:97)
我也把头发撕成了这个。您的代码仅在用户授予了不理想的扩展权限时才有效。
简而言之,如果您为Canvas高级选项打开OAuth 2.0
,Facebook将发送$_REQUEST['signed_request']
以及您的标签应用中请求的每个页面。如果您解析了signed_request,您可以获得有关该用户的一些信息,包括他们是否喜欢该页面。
function parsePageSignedRequest() {
if (isset($_REQUEST['signed_request'])) {
$encoded_sig = null;
$payload = null;
list($encoded_sig, $payload) = explode('.', $_REQUEST['signed_request'], 2);
$sig = base64_decode(strtr($encoded_sig, '-_', '+/'));
$data = json_decode(base64_decode(strtr($payload, '-_', '+/'), true));
return $data;
}
return false;
}
if($signed_request = parsePageSignedRequest()) {
if($signed_request->page->liked) {
echo "This content is for Fans only!";
} else {
echo "Please click on the Like button to view this tab!";
}
}
答案 1 :(得分:19)
您可以使用(PHP)
$isFan = file_get_contents("https://api.facebook.com/method/pages.isFan?format=json&access_token=" . USER_TOKEN . "&page_id=" . FB_FANPAGE_ID);
这将返回三个中的一个:
我认为实现这一目标的唯一不使用令牌方式是刚刚发布的signed_request Jason Siffring。我的助手使用PHP SDK:
function isFan(){
global $facebook;
$request = $facebook->getSignedRequest();
return $request['page']['liked'];
}
答案 2 :(得分:17)
你可以在JavaScript中这样做(建立@dwarfy's response to a similar question):
<html>
<head>
<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"></script>
<style type="text/css">
div#container_notlike, div#container_like {
display: none;
}
</style>
</head>
<body>
<div id="fb-root"></div>
<script>
window.fbAsyncInit = function() {
FB.init({
appId : 'YOUR_APP_ID', // App ID
channelUrl : 'http(s)://YOUR_APP_DOMAIN/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
});
FB.getLoginStatus(function(response) {
var page_id = "YOUR_PAGE_ID";
if (response && response.authResponse) {
var user_id = response.authResponse.userID;
var fql_query = "SELECT uid FROM page_fan WHERE page_id = "+page_id+"and uid="+user_id;
FB.Data.query(fql_query).wait(function(rows) {
if (rows.length == 1 && rows[0].uid == user_id) {
console.log("LIKE");
$('#container_like').show();
} else {
console.log("NO LIKEY");
$('#container_notlike').show();
}
});
} else {
FB.login(function(response) {
if (response && response.authResponse) {
var user_id = response.authResponse.userID;
var fql_query = "SELECT uid FROM page_fan WHERE page_id = "+page_id+"and uid="+user_id;
FB.Data.query(fql_query).wait(function(rows) {
if (rows.length == 1 && rows[0].uid == user_id) {
console.log("LIKE");
$('#container_like').show();
} else {
console.log("NO LIKEY");
$('#container_notlike').show();
}
});
} else {
console.log("NO LIKEY");
$('#container_notlike').show();
}
}, {scope: 'user_likes'});
}
});
};
// 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>
<div id="container_notlike">
YOU DON'T LIKE ME :(
</div>
<div id="container_like">
YOU LIKE ME :)
</div>
</body>
</html>
服务器上的channel.html文件只包含以下行:
<script src="//connect.facebook.net/en_US/all.js"></script>
那里有一些代码重复,但你明白了。这将在用户第一次访问页面时弹出登录对话框(这不是很理想,但有效)。在随后的访问中,不应该弹出任何东西。
答案 3 :(得分:16)
虽然这篇文章已经存在了很长一段时间,但解决方案并不是纯粹的JS。虽然Jason注意到请求权限并不理想,但我认为这是一件好事,因为用户可以明确拒绝它。我仍然发布这个代码,但是(差不多)同样的事情也可以在another post by ifaour中看到。考虑这个只有JS的版本而不太注重细节。
基本代码相当简单:
FB.api("me/likes/SOME_ID", function(response) {
if ( response.data.length === 1 ) { //there should only be a single value inside "data"
console.log('You like it');
} else {
console.log("You don't like it");
}
});
或者,将me
替换为其他人的正确UserID(您可能需要更改以下权限才能执行此操作,例如friends_likes
)如上所述,您需要的不仅仅是基本权限:< / p>
FB.login(function(response) {
//do whatever you need to do after a (un)successfull login
}, { scope: 'user_likes' });
答案 4 :(得分:3)
当用户按下like按钮时,我使用jquery发送数据。
<script>
window.fbAsyncInit = function() {
FB.init({appId: 'xxxxxxxxxxxxx', status: true, cookie: true,
xfbml: true});
FB.Event.subscribe('edge.create', function(href, widget) {
$(document).ready(function() {
var h_fbl=href.split("/");
var fbl_id= h_fbl[4];
$.post("http://xxxxxx.com/inc/like.php",{ idfb:fbl_id,rand:Math.random() } )
}) });
};
</script>
注意:您可以使用一些隐藏的输入文本来获取按钮的ID。在我的情况下,我从“var fbl_id = h_fbl [4];”中的url本身获取它。因为有id的例子: 网址: http://mywebsite.com/post/22/some-tittle
所以我解析了url以获取id,然后将它插入到like.php文件中的数据库中。 通过这种方式你不需要请求权限来知道是否有人按下了类似按钮,但是如果你想知道是谁按下它,则需要权限。