1

ユーザーの電子メール アドレスが必要です。Facebook SDK 内で電子メールのアクセス許可を設定したいと考えています。

これを行うためのアイデアを教えてください。

私のコード:

 @Deprecated
    public void authorize(Activity activity, String[] permissions, final DialogListener listener) {
        permissions =new String[] {"offline_access","video_upload","publish_stream","user_photos","email","read_friendlists"};      
        authorize(activity, permissions, DEFAULT_AUTH_ACTIVITY_CODE, SessionLoginBehavior.SSO_WITH_FALLBACK, listener);
    }

私はこのようにしました。これは機能していません。

4

3 に答える 3

3

これを試して:

you set the permission like 
String[] Permissions = {"email", "offline_access"};
于 2013-02-06T13:35:23.187 に答える
1

以下のように認証コードを変更します。

 public void authorize(Activity activity, String[] permissions,
        int activityCode, final DialogListener listener) {

    boolean singleSignOnStarted = false;

    mAuthDialogListener = listener;

    // Prefer single sign-on, where available.
    if (activityCode >= 0) {
        singleSignOnStarted = startSingleSignOn(activity, mAppId,
                permissions, activityCode);
    }
    // Otherwise fall back to traditional dialog.
    if (!singleSignOnStarted) {
        startDialogAuth(activity, permissions);
    }
}
于 2013-02-06T13:57:26.357 に答える
0

この質問を確認しましたが、非常に簡単です。これがあなたが欲しかったコードです:

Session currentSession = Session.getActiveSession();
    if (currentSession == null || currentSession.getState().isClosed()) {
        Session session = new Session.Builder(context).build();
        Session.setActiveSession(session);
        currentSession = session;
    }

    if (currentSession.isOpened()) {
        // Do whatever u want. User has logged in

    } else if (!currentSession.isOpened()) {
        // Ask for username and password
        OpenRequest op = new Session.OpenRequest((Activity) context);

        op.setLoginBehavior(SessionLoginBehavior.SUPPRESS_SSO);
        op.setCallback(null);

        List<String> permissions = new ArrayList<String>();
        permissions.add("publish_stream");
        permissions.add("user_likes");
        permissions.add("email");
        permissions.add("user_birthday");
        op.setPermissions(permissions);

        Session session = new Builder(MainActivity.this).build();
        Session.setActiveSession(session);
        session.openForPublish(op);
    }

ここで、onActivityResultセッションが開いているかどうかを確認し、userID、access_token などを取得するなど、そこで作業を行います。

これが何らかの形で役立つことを願っています。

于 2013-05-03T10:43:34.957 に答える