Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/295.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php facebook服务器端登录结果为空白页_Php_Facebook - Fatal编程技术网

Php facebook服务器端登录结果为空白页

Php facebook服务器端登录结果为空白页,php,facebook,Php,Facebook,我最近在facebook上做了一个测试应用程序,该应用程序是一个网站应用程序,我只需要用户登录,就可以使用php sdk从应用程序中访问用户信息,当我第一次测试它时,登录过程工作得很好,问题是,当我到达测试页面时,它是完全空白的,而我希望它会回显:HELLO NAME,其中NAME是我的名字,这是代码,我不会发布app id、secret等,因为这些肯定有效,因为登录过程很好: $app_id = "xxxxxxxxxxxx"; $app_secret = "xxxxxxxxxxxx

我最近在facebook上做了一个测试应用程序,该应用程序是一个网站应用程序,我只需要用户登录,就可以使用php sdk从应用程序中访问用户信息,当我第一次测试它时,登录过程工作得很好,问题是,当我到达测试页面时,它是完全空白的,而我希望它会回显:HELLO NAME,其中NAME是我的名字,这是代码,我不会发布app id、secret等,因为这些肯定有效,因为登录过程很好:

   $app_id = "xxxxxxxxxxxx";
   $app_secret = "xxxxxxxxxxxxxxxxxxxxxx";
   $my_url = "http://www.anithro.com/anithroproject/login.php/";
    session_start();
    $code = $_REQUEST["code"];

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

 echo("<script> top.location.href='" . $dialog_url . "'</script>");
   if($_SESSION['state'] && ($_SESSION['state'] === $_REQUEST['state'])) {
 // state variable matches
   $token_url = "https://graph.facebook.com/oauth/access_token?"
   . "client_id=" . $app_id . "&redirect_uri=" . urlencode($my_url)
   . "&client_secret=" . $app_secret . "&code=" . $code;

 $response = file_get_contents($token_url);
 $params = null;
 parse_str($response, $params);
 $_SESSION['access_token'] = $params['access_token'];
 $graph_url = "https://graph.facebook.com/me?access_token=" 
   . $_SESSION['access_token'];

 $user = json_decode(file_get_contents($graph_url));
 echo("Hello " . $user->name);
   }
   else {
     echo("The state does not match. You may be a victim of CSRF.");
     }
   }

我已经完全按照代码进行了操作,为什么我不能访问用户变量?提前谢谢。您可以尝试访问我提供的url,它只是一个空白。

如果您使用的访问令牌经过身份验证,您是否测试了它?您可以将其用于调试工具:

您也可以尝试以下链接: 这里的PHPSDK使用一个类来获取登录用户的基本信息。
检查示例文件夹。

您是否收到任何PHP错误?在我看来,您似乎收到了一个PHP错误,导致代码停止执行。是的,我收到了,它是未经验证的,我现在只想知道为什么在这个示例中没有打印任何内容,我甚至在echo Hello之后添加了代码来回送随机内容。$user->name;但是没有什么会得到回应,当我在所有php下添加html时,它会被打印出来,如果我在上述代码块之外添加php,它也会被打印出来。好吧,我错了,只要我想打印,就不会打印任何php,只打印html内容;它将返回$user的所有值,如果这是您所期望的或不是。没有发生任何事情,也没有打印任何内容,您是否有其他方法登录您推荐的用户,但这仍然允许我使用php sdk访问他/她的数据,您知道这样的:$userdata=$facebook->api'/me';和$frienddata=$facebook->apiarray'method'=>'fql.query','query'=>'选择uid,用户名从uid插入的用户中选择uid2从uid1=me且为_app_user=1'的朋友中选择uid2;?那么这只意味着你的脚本有问题。此应用程序是否具有网站URL?域名呢?在developer.facebook.com上?我将尝试给你一个示例代码。