0

我正在使用来自 facebook 示例的以下脚本:

该脚本很好地抓取了电子邮件,但家乡和位置在我的服务器上触发了 500 错误。我需要抓取数据进行统计。

<?php 

$app_id = "API_ID_GOES_HERE";
$app_secret = "SECRET_GOES_HERE";
$my_url = "REDIRECT_URL_GOES_HERE";
$permissions ="user_hometown,user_location,email";

session_start();
$code = $_REQUEST["code"];

if(empty($code)) {
 $_SESSION['state'] = md5(uniqid(rand(), TRUE)); //CSRF protection
 $dialog_url = "http://www.facebook.com/dialog/oauth?client_id=" 
. $app_id . "&redirect_uri=" . urlencode($my_url) . "&scope=".$permissions. 
  "&state="
   . $_SESSION['state'];

 echo("<script> top.location.href='" . $dialog_url . "'</script>");
  }

if($_REQUEST['state'] == $_SESSION['state']) {
 $token_url = "https://graph.facebook.com/oauth/access_token?"
   . "client_id=" . $app_id . "&redirect_uri=" . urlencode($my_url)
   . "&scope=".$permissions. "&client_secret=" . $app_secret . "&code=" . $code;

 $response = file_get_contents($token_url);
 $params = null;
 parse_str($response, $params);

 $graph_url = "https://graph.facebook.com/me?access_token=" 
   . $params['access_token'];

 $user = json_decode(file_get_contents($graph_url));

 echo("Hello " . $user->name);
 echo ("Location ". $user->location);


}
else {
  echo("The state does not match. You may be a victim of CSRF.");
}

?>
4

2 回答 2

2

我找到了答案。使用这个 $user->hometown->name 会得到 Hometown 数组和 Name 对象。

前任。[hometown] => stdClass Object ([id] => 111806898837603 [name] => 德克萨斯州圣安东尼奥)

$user->hometown->name  

输出:

德克萨斯州圣安东尼奥

于 2011-10-24T17:12:22.813 回答
1

我会使用您创建的 URL 从图形 api 中获取用户信息(即 $graph_url)并将它们粘贴到您的浏览器中以检查 facebook 返回的数据,然后从那里开始。如果 URL 正在返回正确的信息,那么您知道您正在获取正确的数据。使用 Graph API Explorer ( https://developers.facebook.com/tools/explorer ) 来测试您为图形 API 创建的 URL。您可以看到授予不同权限的结果是什么样的,并为响应编写相应的代码。希望有帮助!

于 2011-10-24T09:51:22.593 回答