it-swarm.com.ru

Как проверить, вошел ли пользователь в FB SDK 4.0 для Android?

Несколько дней назад я ввел FB Login в свое приложение, и сегодня я обнаружил, что большинство из реализованных мною функций устарело.

Раньше я использовал Session, чтобы увидеть, вошел ли пользователь в систему или нет. Однако это не работает с новым SDK.

В соответствии с их документами, мы можем использовать AccessToken.getCurrentAccessToken() и Profile.getCurrentProfile(), чтобы проверить, вошел ли пользователь в систему, но я не смог их использовать.

Я попробовал что-то вроде этого:

if(AccessToken.getCurrentAccessToken() == null)

Интересно, сработает ли это, если бы я мог использовать это внутри этого (что также предоставляется FB):

LoginManager.getInstance().registerCallback(callbackManager, new LoginManager.Callback() {...});

Однако я получаю "Не удается разрешить символ" Обратный вызов "".

РЕДАКТИРОВАТЬ !!!!!!

Хорошо, поэтому я смог проверить, вошел ли пользователь, используя следующее:

On onCreate:

accessTokenTracker = new AccessTokenTracker() {
        @Override
        protected void onCurrentAccessTokenChanged(AccessToken oldAccessToken, AccessToken newAccessToken) {
            updateWithToken(newAccessToken);
        }
    };

Затем это вызывает мой метод updateWithToken:

private void updateWithToken(AccessToken currentAccessToken) {
    if (currentAccessToken != null) {

            LOAD ACTIVITY A!

    } else {

            LOAD ACTIVITY B!
    }
}

Теперь проблема в том, что: если пользователь уже использовал приложение и ранее не входил в систему, я могу это проверить! Но если пользователь впервые использует приложение, мой AccessTokenTracker никогда не вызывает updateWithToken.

Буду очень признателен, если кто-нибудь сможет помочь.

Спасибо!

63
Felipe

Я понял!

Сначала убедитесь, что вы инициализировали свой FB SDK. Во-вторых, добавьте следующее:

accessTokenTracker = new AccessTokenTracker() {
        @Override
        protected void onCurrentAccessTokenChanged(AccessToken oldAccessToken, AccessToken newAccessToken) {
            updateWithToken(newAccessToken);
        }
    };

Это будет вызвано, когда произойдет изменение текущих токенов доступа. Это означает, что это поможет вам, только если пользователь уже вошел в систему.

Далее мы добавим это к нашему методу onCreate():

updateWithToken(AccessToken.getCurrentAccessToken());

Тогда, конечно, наш метод updateWithToken():

private void updateWithToken(AccessToken currentAccessToken) {

    if (currentAccessToken != null) {
        new Handler().postDelayed(new Runnable() {

            @Override
            public void run() {
                Intent i = new Intent(SplashScreen.this, GeekTrivia.class);
                startActivity(i);

                finish();
            }
        }, SPLASH_TIME_OUT);
    } else {
        new Handler().postDelayed(new Runnable() {

            @Override
            public void run() {
                Intent i = new Intent(SplashScreen.this, Login.class);
                startActivity(i);

                finish();
            }
        }, SPLASH_TIME_OUT);
    }
}

Это сделало это для меня! знак равно

35
Felipe

Гораздо более простое решение сработало для моего случая (хотя я не знаю, является ли это более элегантным способом):

public boolean isLoggedIn() {
    AccessToken accessToken = AccessToken.getCurrentAccessToken();
    return accessToken != null;
}
134
Felipe Mosso

Моя дилемма использования AccessToken и AccessTokenTracker для проверки статуса входа в систему состоит в том, что когда AccessToken готов и функция обратного вызова трекера вызвана, но профиль еще не готов, таким образом, я не могу получить или отобразить имя Facebooker's в этот момент.

Мое решение состоит в том, чтобы проверить текущий профиль! = Null и использовать его трекер, чтобы иметь имя Facebooker одновременно:

    ProfileTracker fbProfileTracker = new ProfileTracker() {
        @Override
        protected void onCurrentProfileChanged(Profile oldProfile, Profile currentProfile) {
            // User logged in or changed profile
        }
    };

Проверьте статус входа и затем получите имя пользователя:

Profile profile = Profile.getCurrentProfile();
if (profile != null) {
    Log.v(TAG, "Logged, user name=" + profile.getFirstName() + " " + profile.getLastName());
}
9
Tony

Вы можете использовать тот же способ, который Фелипе упоминал в своем ответе, или вы можете использовать два других способа. Но, похоже, AccessTokenTracker - это удобный способ, поскольку он помогает отслеживать токены доступа (используется с классом ProfileTracker).

  1. Если вы используете пользовательскую кнопку для входа в систему, используйте функцию CallManager

Например

В вашем макете XML

    <Button
        Android:id="@+id/my_facebook_button"
        Android:background="@drawable/btnfacebook"
        Android:onClick="facebookLogin"/>

В вашей деятельности

    //Custom Button
    Button myFacebookButton = (Button) findViewById(R.id.my_facebook_button);

Кнопка onclick Слушатель

public void facebookLogin(View view) {
        LoginManager.getInstance().logInWithReadPermissions(this, Arrays.asList("public_profile", "user_friends"));
    }

В конце Обратный звонок LoginManager

 //Create callback manager to handle login response
        CallbackManager callbackManager = CallbackManager.Factory.create();

       LoginManager.getInstance().registerCallback(callbackManager, new FacebookCallback<LoginResult>() {
           @Override
           public void onSuccess(LoginResult loginResult) {
               Log.i(TAG, "LoginManager FacebookCallback onSuccess");
               if(loginResult.getAccessToken() != null) {
                   Log.i(TAG, "Access Token:: " + loginResult.getAccessToken());
                   facebookSuccess();
               }
           }

           @Override
           public void onCancel() {
               Log.i(TAG, "LoginManager FacebookCallback onCancel");
           }

           @Override
           public void onError(FacebookException e) {
               Log.i(TAG, "LoginManager FacebookCallback onError");
           }
       });
  1. Если вы используете кнопку (com.facebook.login.widget.LoginButton), предоставленную в SDK, используйте функцию обратного вызова LoginButton (это подробно описано в справочном документе - https://developers.facebook.com/docs/facebook -login/Android/v2. )

Например

В вашем макете XML

<com.facebook.login.widget.LoginButton
                Android:id="@+id/login_button"
                Android:layout_width="wrap_content"
                Android:layout_height="wrap_content"
                Android:layout_gravity="center_horizontal"/>

В вашей деятельности

    //Facebook SDK provided LoginButton
    LoginButton loginButton = (LoginButton) findViewById(R.id.login_button);
    loginButton.setReadPermissions("user_friends");
    //Callback registration
    loginButton.registerCallback(callbackManager, new FacebookCallback<LoginResult>() {
        @Override
        public void onSuccess(LoginResult loginResult) {
            // App code
            Log.i(TAG, "LoginButton FacebookCallback onSuccess");
            if(loginResult.getAccessToken() != null){
                Log.i(TAG, "Access Token:: "+loginResult.getAccessToken());
                facebookSuccess();
            }

        }

        @Override
        public void onCancel() {
            // App code
            Log.i(TAG, "LoginButton FacebookCallback onCancel");
        }

        @Override
        public void onError(FacebookException exception) {
            // App code
            Log.i(TAG, "LoginButton FacebookCallback onError:: "+exception.getMessage());
            Log.i(TAG,"Exception:: "+exception.getStackTrace());
        }
    });

Не забудьте вызвать callbackManager.onActivityResult(requestCode, resultCode, data); в вашем Activity onActivityResult ()

3
binary

Согласно документация facebook вы можете сделать это:

AccessToken accessToken = AccessToken.getCurrentAccessToken();
boolean isLoggedIn = accessToken != null && !accessToken.isExpired();
3
Asad

Уже поздно отвечать, но теперь в версии 4.25.0 of Facebook SDK есть метод:

public void retrieveLoginStatus(Context context,
                                LoginStatusCallback responseCallback)

Который заявляет:

Получает статус входа для пользователя. Это вернет токен доступа к приложению, если пользователь вошел в Facebook для приложения Android на том же устройстве, и этот пользователь ранее вошел в приложение. Если маркер доступа был получен, то будет показан тост, сообщающий пользователю, что он вошел в систему.

И может быть использован как:

LoginManager.getInstance().retrieveLoginStatus( this, new LoginStatusCallback()
{
    @Override
    public void onCompleted( AccessToken accessToken )
    {
        GraphRequest request = GraphRequest.newMeRequest( accessToken, new GraphRequest.GraphJSONObjectCallback()
        {
            @Override
            public void onCompleted( JSONObject object, GraphResponse response )
            {
                Log.e( TAG, object.toString() );
                Log.e( TAG, response.toString() );

                try
                {
                    userId = object.getString( "id" );
                    profilePicture = new URL( "https://graph.facebook.com/" + userId + "/picture?width=500&height=500" );
                    Log.d( "PROFILE_URL", "url: " + profilePicture.toString() );
                    if ( object.has( "first_name" ) )
                    {
                        firstName = object.getString( "first_name" );
                    }
                    if ( object.has( "last_name" ) )
                    {
                        lastName = object.getString( "last_name" );
                    }
                    if ( object.has( "email" ) )
                    {
                        email = object.getString( "email" );
                    }
                    if ( object.has( "birthday" ) )
                    {
                        birthday = object.getString( "birthday" );
                    }
                    if ( object.has( "gender" ) )
                    {
                        gender = object.getString( "gender" );
                    }

                    Intent main = new Intent( LoginActivity.this, MainActivity.class );
                    main.putExtra( "name", firstName );
                    main.putExtra( "surname", lastName );
                    main.putExtra( "imageUrl", profilePicture.toString() );
                    startActivity( main );
                    finish();
                }
                catch ( JSONException e )
                {
                    e.printStackTrace();
                }
                catch ( MalformedURLException e )
                {
                    e.printStackTrace();
                }

            }
        } );
        //Here we put the requested fields to be returned from the JSONObject
        Bundle parameters = new Bundle();
        parameters.putString( "fields", "id, first_name, last_name, email, birthday, gender" );
        request.setParameters( parameters );
        request.executeAsync();
    }

    @Override
    public void onFailure()
    {
        Toast.makeText( LoginActivity.this, "Could not log in.", Toast.LENGTH_SHORT ).show();
    }

    @Override
    public void onError( Exception exception )
    {
        Toast.makeText( LoginActivity.this, "Could not log in.", Toast.LENGTH_SHORT ).show();
    }
} );
1
Talha