2

このコードを使用して、ユーザーのウォールに投稿しています:

require 'fb/src/facebook.php';
$facebook = new Facebook(array(
   'appId' => 'xxx',
   'secret' => 'xxx',
));
$params = array(
    'canvas' => 1,
    'scope' => 'publish_stream,email,user_about_me,user_birthday,user_website',
    'redirect_uri' => 'urlhere',
);

$fb_session = $facebook->getUser();

// Session based API call.
if ($fb_session) 
{
    try 
    {
         $args = array(
                  'message' =>  $_GET['by'],
                  'link' => 'linkhere/',
                  'caption' => $_GET['test']
                 );
         $post_id = $facebook->api("/me/feed", "post", $args);
     } 
     catch (Exception $e) 
     {

         $fb_login_url = $facebook->getLoginUrl($params);
         echo $e->getMessage();
     }
} 
else 
{
     $fb_login_url = $facebook->getLoginUrl($params);
} 

コードは、ユーザーがログイン部分をクリックして投稿するまで機能しています。その後、URL には acode = xxxzzと astate =yyyが含まれていますが、$fb_session is 0.

これは、変更なしで機能する場合があります。助けてください!

4

2 に答える 2

1

ユーザーの Facebook ウォールに投稿しようとするときは、アクセス トークンを含める必要があります。

最初にアクセス トークンを取得します。

$fbToken = NULL;
$fbToken = $facebook->getAccessToken();

直後の$fb_session = $facebook->getUser();

そしてそれを$args配列に含めます:

 'access_token' => $fbToken 

セッションが作成されていないか、アクセス トークンが有効でない場合は、ユーザーをリダイレクトして Facebook アプリを再承認する必要があります。

では、ELSE追加する必要があります

   header("Location: $fb_login_url ");

$fb_login_url = $facebook->getLoginUrl($params);

  • 他のすべてが正しいが、access_token が無効であると仮定すると、header("Location: $fb_login_url ");前に も含める必要があります。echo $e->getMessage();
于 2013-08-19T12:04:22.630 に答える
0

どちらの場合も getloginurl を使用しています

すべきではないか

if ($fb_session) {
try {
$args = array(
'message' =>  $_GET['by'],
'link' => 'linkhere/',
'caption' => $_GET['test']
);
$post_id = $facebook->api("/me/feed", "post", $args);
} catch (Exception $e) {
$fb_logout_url = $facebook->getLogoutUrl;
.
.
.
于 2013-08-12T09:07:12.010 に答える