我在开发阶段有一个Facebook PHP SDK应用程序,并且我陷入困境...该应用的逻辑是:

首先,用户必须喜欢该页面(应用程序在此上)//效果很好:)如果授予权限,则可以使用权限请求:APP_DATA变量已通过,用户收回图片。

APP_DATA变量是必要的,因为如果用户再次获得权限后,用户单击该应用程序,则自动获取新图片。使用app_data不会。

我的问题是此链接:

    $params = array(
  scope => 'publish_stream,user_photos',
  redirect_uri => 'http://www.facebook.com/XXXXX?sk=app_YYYYYY&app_data=1'
    );

<a href="<?php echo $facebook->getLoginUrl($params); ?>">Accept</a>

如果我单击它,则应用程序显示空白页,而什么也没有发生... :(在直接通话中,该应用程序运行时不会出现任何错误。

有人可以帮我吗?

// 对不起我的英语不好...

谢谢!

整个index.php是:

这是整个index.php:

<?php
require 'facebook.php';

$facebook = new Facebook(array(
'appId' => 'xxxxx',
'secret' => 'yyyyy',
'baseUrl' => 'http://hosting.address/',
'appBaseUrl' => 'http://apps.facebook.com/app-name/',
'fileUpload' => 'true',
));
// Get User ID
$user = $facebook->getUser();

$params = array(
  scope => 'publish_stream,user_photos',
  redirect_uri => 'http://www.facebook.com/xxxxx?sk=app_yyyyy&app_data=1'
    );

$signed_request = $facebook->getSignedRequest();
$app_data = $signed_request["app_data"];


?>
                    <!doctype html>
                    <html xmlns:fb="http://www.facebook.com/2008/fbml">
                    <head>
                    <title>the title</title>
                    <style>
                        a:link    {color:#ffffff;}
                        a:visited {color:#ffffff;}
                        a:hover   {color:#ececec;}
                        a:active  {color:#1f1f1f;}
                        a:link    {text-decoration: none}
                    </style>
                    </head>
                    <body>
<?php if ($user){

    try {
        $user_profile = $facebook->api('/me');
        $likes = $facebook->api("/me/likes/123123123"); //page ID

            if( !empty($likes['data']) ){

                $scope = 'publish_stream,user_photos';
                $scope_params = explode(',',$scope);

                $permissions = $facebook->api("/me/permissions");
                    if( array_key_exists('publish_stream', $permissions['data'][0]) &&  array_key_exists('user_photos', $permissions['data'][0]) && isset($app_data)) {


                        $file = "1.jpg";
                        $message = 'bla bla';

                        $ret_obj = $facebook->api('/me/photos', 'POST', array(
                                                                        'source' => '@' . $file,
                                                                        'message' => $message,
                                                                    )
                                                                );
                        echo "<img width=\"520px\" src=\"1.jpg\" />";
                    } else {
                    ?>
<a href="<?php echo $facebook->getLoginUrl($params); ?>">accept</a></td>
<a href="http://www.facebook.com/pageurl">deny</a></td>

                    <?
                    }
            }else{
                echo "<img width=\"520px\" src=\"no-fan.jpg\" />";
            }

    } catch (FacebookApiException $e) {
        echo '<pre>'.htmlspecialchars(print_r($e, true)).'</pre>';
        $user = null;
        }
    }

    if ($user) {
        } else {
            $loginUrl = $facebook->getLoginUrl($params);
            echo '<script type="text/javascript">top.location.href = "'.$loginUrl .'";</script>';
        }

        ?>

</body>
</html>
有帮助吗?

解决方案

在我深入研究Facebook应用程序的世界之前,我已经有过这个。

我最终所做的就是为我 redirect_uri 我在域上使用了一个页面,例如 https://domain.com/facebook/redirect.php 在redirect.php中,我将有:

// user didn't give app permissions
if (isset($_GET['error_reason']))
{
    header( 'Location: http://www.facebook.com/FANPAGE' ) ;
}
else 
{
    header( 'Location: http://www.facebook.com/XXXXX?sk=app_YYYYYY' ) ;
}
许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top