17


9

ユーザーが新しいfacebook php apiでログインしているかどうかを確認する方法

PHP APIを使用して、古いFBアプリを新しいグラフAPIに移行しています

私は2つのページを持っています:公開ページ(ユーザーログインを必要としない)とプライベートページ(実行する)

したがって、私のアプリケーションのすべてのphpページのコードは次のように機能します。

if (this_page_requires_user_login){
      $facebook = new Facebook(...) ;
      $session = $facebook->getSession ;
      if (!$session){
              $url =$facebook.getLoginUrl(array(next => current_page );
              echo "" ;

}
// the rest of the code continues here

ご覧のとおり、この作業方法はすべてのページをログインURLに転送しますが、動作している間も低速で、&session = \ {bla}文字列を非常に1つのURLに追加します。

ログインページにリダイレクトする前に、ユーザーがすでにログインしている場所を確認する方法が必要です。 しかし、私はPHP APIでそのような方法を見つけることができません。 これを行うための最良の方法は何ですか?

編集

これはトリックを行うように見えた

if ($session) {
  try {
    $me = $facebook->api('/me');
    if ($me) {
       // here comes your code for user who is logged in
    }
  } catch (FacebookApiException $e) {
    login()
  }
}else{
 login()
}

function login(){

  $url =$facebook.getLoginUrl(array(next => current_page );


      echo "" ;
}

1 Answer


19


コードを正しく読んでいる場合、セッションが返されない場合にのみリダイレクトを行いますか? Facebookの例のコメントによると、たとえセッションを取り戻したとしても、それがまだ有効であると仮定することはできません。 。 ログインしているユーザーを必要とするAPI呼び出しを試みるだけで、確実にわかります。 これは、ログイン/ログアウトステータスを確実に判断するために私が見た最良の方法です。

if ($session) {
  try {
    $me = $facebook->api('/me');
    if ($me) {
      //User is logged in
    }
  } catch (FacebookApiException $e) {
    //User is not logged in
  }
}