0

私は自分のウェブサイトを登録するために Facebook 情報をほとんど必要としない APP を開発しています。

最初は facebook SDK 1.5 を使用していましたが、すべてうまく機能しています。facebook が 2013 年 6 月以降、古い (v2.0 以下) SDK のサポートを停止すると言うまで。

そのため、3.0 にアップグレードし、コードを書き直さなければなりません。

Facebookの公式チュートリアルについて読んだ後、これまでに行ったことは次のとおりです。

manifst.xml

<!-- some stuff -->
<uses-permission android:name="android.permission.INTERNET" />
<meta-data android:name="com.facebook.sdk.ApplicationId" android:value="@string/fbAppId"/>
<activity android:name="com.facebook.LoginActivity" android:label="@string/app_name" />

文字列.xml

<!-- some stuff -->
<string name="fbAppId">1234567890</string> <!-- You do know this ID is fake, right ? -->

コード

public class LoginFragment extends SherlockFragment
{
  private UiLifecycleHelper uiHelper;

  private Session.StatusCallback callback=new Session.StatusCallback()
  {
    @Override
    public void call(final Session session, final SessionState state, final Exception exception)
    {
      onSessionStateChange(session, state, exception);
    }
  };

  @Override
  public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState)
  {
    View view=inflater.inflate(R.layout.login_fragment, container, false);

    LoginButton authButton=(LoginButton)view.findViewById(R.id.btnLogin);
    authButton.setFragment(this);
    authButton.setReadPermissions(Arrays.asList("basic_info", "user_status", "email"));

    return view;
  }

  @Override
  public void onCreate(Bundle savedInstanceState)
  {
    super.onCreate(savedInstanceState);
    uiHelper=new UiLifecycleHelper(getActivity(), callback);
    uiHelper.onCreate(savedInstanceState);
  }

  @Override
  public void onResume()
  {
    super.onResume();

    // For scenarios where the main activity is launched and user
    // session is not null, the session state change notification
    // may not be triggered. Trigger it if it's open/closed.
    Session session=Session.getActiveSession();
    if(session!=null&&(session.isOpened()||session.isClosed()))
    {
      onSessionStateChange(session, session.getState(), null);
    }

    uiHelper.onResume();
  }

  @Override
  public void onActivityResult(int requestCode, int resultCode, Intent data)
  {
    super.onActivityResult(requestCode, resultCode, data);
    uiHelper.onActivityResult(requestCode, resultCode, data);
  }

  @Override
  public void onPause()
  {
    super.onPause();
    uiHelper.onPause();
  }

  @Override
  public void onDestroy()
  {
    super.onDestroy();
    uiHelper.onDestroy();
  }

  @Override
  public void onSaveInstanceState(Bundle outState)
  {
    try
    {
      super.onSaveInstanceState(outState);
      setUserVisibleHint(true);
      uiHelper.onSaveInstanceState(outState);
    }
    catch(Exception e)
    {
      e.printStackTrace();
      Log.w(Constants.TAG, "Error on save instance state, "+e.toString());
    }
  }

  private void onSessionStateChange(Session session, SessionState state, Exception exception)
  {
    if(state.isOpened()) //I don't know why state is always not opened......?
    {
      Request request=Request.newMeRequest(session, new Request.GraphUserCallback()
      {
        @Override
        public void onCompleted(GraphUser user, Response response)
        {
          if(user!=null)
          {
            Log.i(Constants.TAG, "Logged in...");
            Log.d("user fname", user.getFirstName());
            Log.d("user lname", user.getLastName());
            Log.d("user username", user.getUsername());
            Log.d("user email", (String) response.getGraphObject().getProperty("email"));
          }
          else
          {
            Log.i(Constants.TAG, "Logged out...");
          }

        }
      });

      Request.executeBatchAsync(request);
    }
  }
}

アプリを実行すると、Facebook のログイン ボタンが表示されます。

それを押すと、ダイアログが表示され、APP が Facebook 情報、電子メールなどにアクセスすることを許可するように求められます。

そして、はいを押しても何も起こらず、LogCatでも何も出てこない...

ユーザーが実際に Facebook にログインしていることを確認し、その情報にアクセスするにはどうすればよいですか?

4

1 に答える 1