3

アプリケーションの前の部分で、ユーザーがへのアプリケーション要求を受け入れる限り、正常に機能する次のコードがありますpublish_stream

# The facebook library
require_once("/var/www/facebook-php-sdk-master/src/facebook.php");

# Create facebook object
$config = array();
$config['appId'] = 'appId_here';
$config['secret'] = 'secret_here';
$config['fileUpload'] = false; // optional

$facebook = new Facebook($config); 

$user_id = $facebook->getUser();

if ($user_id) {

    try {

        $user_profile = $facebook->api('/me','GET');

        #check permissions
        $api_call = array(
                'method' => 'users.hasAppPermission',
                'uid' => $user_id,
                'ext_perm' => 'publish_stream'
        );

        #set to true if true...
        $can_offline = $facebook -> api( $api_call );

        #is it true?
        if( $can_offline ) {

            $post =  array(
                'message' => 'post_a_message'
            );

            $facebook->api('/' . $_GET["id"] . '/feed', 'POST', $post);

        } else {

            // can't post message - don't have permission

        }

    } catch (FacebookApiException $e) {

        error_log($e);
        exit;

    }

} else {

    error_log("user not logged in");
    exit;

}

else statementこれを解決するために、現在上記のコードにコメントのみが含まれているに次のコードを挿入しようとしました// can't post message - don't have permission

その中に挿入しようとしたコードelseは次のとおりです。

$loginUrl = $facebook->getLoginUrl( array( 'scope' => 'publish_stream' ) );
header("Location: ".$loginUrl);

これは、ユーザーが私のアプリの許可を受け入れる限り機能しますpublish_stream。ただし、ユーザーが同意しない場合、私のアプリはユーザーに同意を求め続けますpublish_stream。ユーザーが受け入れないことを決定した場合、どうすればそのループが発生しないようにできますか?

4

3 に答える 3

4

私が覚えている限り、リンクを含む$facebook -> getLoginUrlパラメーターを取ることができますcancel_url。ユーザーがアプリにアクセス許可を与えていない場合は、ユーザーをリダイレクトする必要があります。

したがって、コードは次のようになります

$login_url = $facebook -> getLoginUrl( array(
'scope' => 'publish_stream',
'cancel_url' => YOUR_LINK_HERE
));
于 2013-02-15T09:13:37.060 に答える
2

動作するコードは次のとおりです。確認してください:

ページ名:events.php

$redirect_uri = https://localhost/facebook_page/events.php同じページに戻っていることがわかります。

<?php

$facebook_appid         = "your appid";                     // Facebook appplication id
$facebook_secret        = "your app secret";                // Facebook secret id
$redirect_uri           = "https://localhost/facebook_page/events.php";   // return url to our application after facebook login ## should be SAME as in facebook application
$scope                  = "publish_stream"; // User permission for facebook

$profile_id             = "profile_id";// Where do you want to post it(profile id - It is a number)

$code                   = $_REQUEST["code"]?$_REQUEST["code"]:"";

if(empty($code)) {
    $_SESSION['state']  = rand(); // CSRF protection
    $dialog_url         = "https://www.facebook.com/dialog/oauth?client_id=". $facebook_appid . "&redirect_uri=" . urlencode($redirect_uri) . "&state=". $_SESSION['state'] . "&scope=".$scope;
    header("location:".$dialog_url);
}

if($_SESSION['state'] && ($_SESSION['state'] == $_REQUEST['state'])) {
    $token_url          = "https://graph.facebook.com/oauth/access_token?". "client_id=" . $facebook_appid . "&redirect_uri=" . urlencode($redirect_uri). "&client_secret=" . $facebook_secret . "&code=" . $code;
    $response           = @file_get_contents($token_url);

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

    $access_token       = $params['access_token'];


}

?>

<!-- Here you can use 
      message, picture, link, name, caption, description, source, place, tags 
     as input fields-->

<form enctype="multipart/form-data" method="POST" action="https://graph.facebook.com/<?php echo $profile_id;?>/feed?access_token=<?php echo $access_token; ?>">
    <input type="text" name="message" value="test" />
    <input type="submit" name="submit" value="Submit" />
</form>

jqueryを使用して投稿することもできます。

于 2013-02-20T06:57:20.400 に答える
1

次のコードを使用して、ユーザーが許可の公開を許可しているかどうかを確認します。

$permissions = $facebook->api('me/permissions');
if( array_key_exists('publish_stream', $permissions['data'][0]) ) {
    //Continue with posting on users wall
} else {
    //Continue without posting on users wall
}
于 2013-02-19T07:44:02.047 に答える