Facebook Access令牌始终为空

时间:2017-07-12 17:58:20

标签: android facebook

我的主Activity中有一些代码,如果AccessToken.getCurrentAccessToken()为null,则调用我的facebook登录活动类:

import android.content.Intent;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import android.widget.Toast;

import com.facebook.AccessToken;
import com.facebook.AccessTokenTracker;
import com.facebook.CallbackManager;
import com.facebook.FacebookCallback;
import com.facebook.FacebookException;
import com.facebook.Profile;
import com.facebook.ProfileTracker;
import com.facebook.login.LoginManager;
import com.facebook.login.LoginResult;

import java.util.Arrays;

import matthewboyle.lurker_android.MainFeedScreen;
import matthewboyle.lurker_android.utilities.ConnectionChecker;

/**
 * Created by matthewboyle on 28/05/2017.
 */

public class FacebookLogin extends AppCompatActivity {
    private CallbackManager mCallbackManager;
    private AccessTokenTracker accessTokenTracker;
    private ProfileTracker profileTracker;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        mCallbackManager = CallbackManager.Factory.create();
        accessTokenTracker = new AccessTokenTracker() {
            @Override
            protected void onCurrentAccessTokenChanged(AccessToken oldAccessToken, AccessToken currentAccessToken) {
                Log.d("facebook", "onCurrentAccessTokenChanged");


            }
        };
        profileTracker = new ProfileTracker() {
            @Override
            protected void onCurrentProfileChanged(Profile oldProfile, Profile currentProfile) {
                Log.d("facebook", "onCurrentProfileChanged");

            }
        };
        accessTokenTracker.startTracking();
        profileTracker.startTracking();

        LoginManager.getInstance().registerCallback(mCallbackManager,
                new FacebookCallback<LoginResult>() {
                    @Override
                    public void onSuccess(LoginResult loginResult) {
                        Log.d("facebook", "in on success");
                        AccessToken accessToken = loginResult.getAccessToken();
                        Log.d("permissions", accessToken.getPermissions().toString());

                        Log.d("facebook", "in on success,got a token and its "+accessToken);

                    }

                    @Override
                    public void onCancel() {
                        Log.d("facebook", "in cancel");

                    }

                    @Override
                    public void onError(FacebookException exception) {
                        Log.d("facebook", "in error");
                        Log.d("facebook", exception.toString());




                    }


                });
        LoginManager.getInstance().logInWithReadPermissions(this, Arrays.asList("public_profile", "user_posts","user_likes","user_about_me","user_managed_groups","user_tagged_places"));
        Log.d("facebook", "Done so redirecting with "+AccessToken.getCurrentAccessToken());

        startActivity(new Intent(FacebookLogin.this,MainFeedScreen.class));


    }
    @Override
    protected void onActivityResult(int requestCode, int responseCode, Intent intent) {
        super.onActivityResult(requestCode, responseCode, intent);
        //Facebook login
        mCallbackManager.onActivityResult(requestCode, responseCode, intent);

    }
}

如果我运行此代码,我得到的唯一打印语句是:

 Done so redirecting with null

它似乎根本没有击中班上的任何其他方法。

值得一提的是,在重新安装应用程序之前,此代码工作正常。我进入Facebook并在我的应用程序中更新了哈希键,但这似乎没有帮助。但是,由于哈希密钥,我没有看到任何错误。

感谢任何帮助。

2 个答案:

答案 0 :(得分:7)

您需要在“onSuccess”回调中移动“startActivity”行,如下所示:

LoginManager.getInstance().registerCallback(mCallbackManager,
            new FacebookCallback<LoginResult>() {
                @Override
                public void onSuccess(LoginResult loginResult) {
                    Log.d("facebook", "in on success");
                    AccessToken accessToken = loginResult.getAccessToken();
                    Log.d("permissions", accessToken.getPermissions().toString());

                    Log.d("facebook", "in on success,got a token and its "+accessToken);

                    Log.d("facebook", "Done so redirecting with "+AccessToken.getCurrentAccessToken());

                    startActivity(new Intent(FacebookLogin.this,MainFeedScreen.class));

                }

                @Override
                public void onCancel() {
                    Log.d("facebook", "in cancel");

                }

                @Override
                public void onError(FacebookException exception) {
                    Log.d("facebook", "in error");
                    Log.d("facebook", exception.toString());




                }


            });

答案 1 :(得分:1)

我正在使用Fb SDK 4.1,此代码段对我有用:

正如@Duda所说,你需要移动&#34; startActivity&#34;你的&#34; onSuccess&#34;回调

@Override
public void onSuccess(LoginResult loginResult) {

    AccessToken accessToken = loginResult.getAccessToken();

    Log.d("facebook", "Done so redirecting with "+accessToken.getToken());

    startActivity(new Intent(FacebookLogin.this,MainFeedScreen.class));

}