私は自分のウェブサイトを登録するために 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 にログインしていることを確認し、その情報にアクセスするにはどうすればよいですか?