если (session.isOpen ()), вход в Facebook на Android всегда возвращает false

Я пытаюсь реализовать простое действие в своем приложении для Android, где пользователю предлагается войти в систему через Facebook, чтобы получить «лайки» пользователя. Итак, сначала я тестирую простой логин через фейсбук. Я использую точный код «Начало работы с Facebook SDK для Android» - Шаг 6 (https://developers.facebook.com/docs/getting-started/facebook-sdk-for-android/3.0/) но почему-то не работает. Когда я отладил код, я понял, что следующее условие:

if(session.isOpen()) 

являетсяВСЕГДА возвращает false, даже если я уже зашел на Facebook. Я перепробовал все, чтобы это исправить, но, похоже, ничего не работает.

Кто-нибудь имел эту проблему или знает, как ее исправить?

РЕДАКТИРОВАТЬ: Я пытаюсь этот тест на моем телефоне напрямую, а не на эмуляторе. Я не знаю, может ли это быть проблемой.

Заранее спасибо!

И я попробовал это решениеsession.isOpened () возвращает false, даже если вы успешно вошли в Facebook но использование java 6 или 7 все равно дало тот же хеш-ключ.

РЕДАКТИРОВАТЬ 2: Я тоже попробовал то же самое, но с немного другим подходом.http://sonyarouje.com/2011/09/18/facebook-hash-key-for-android-apps/ У меня все та же проблема.session.isOpen () Метод всегда возвращает ложь.

РЕДАКТИРОВАТЬ 3: Вот последний код, который я пробовал. Я не думаю, что есть какие-либо ошибки в logcat. В любом случае, я свяжу это здесь на всякий случай, если я что-то упустил.

package com.example.danandroidapp;
import java.util.Arrays;

import com.facebook.FacebookException;
import com.facebook.Request;
import com.facebook.Response;
import com.facebook.Session;
import com.facebook.SessionState;
import com.facebook.model.GraphUser;
import com.facebook.widget.LoginButton;
import com.facebook.widget.LoginButton.OnErrorListener;

import android.os.Bundle;
import android.app.Activity;
import android.util.Log;
import android.view.Menu;
import android.widget.TextView;

public class MainActivity extends Activity {

    private String TAG = "MainActivity";
    private TextView lblEmail;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        lblEmail = (TextView) findViewById(R.id.lblEmail);

        LoginButton authButton = (LoginButton) findViewById(R.id.authButton);

        authButton.setOnErrorListener(new OnErrorListener() {
            @Override
            public void onError(FacebookException error) {
                Log.i(TAG, "Error " + error.getMessage());
            }
        });

        authButton.setReadPermissions(Arrays.asList("basic_info", "email"));
        authButton.setSessionStatusCallback(new Session.StatusCallback() {

        @Override
        public void call(Session session, SessionState state, Exception exception) {
            if(session.isOpened()) {
                Log.i(TAG, "Access Token " + session.getAccessToken());
                Request.executeMeRequestAsync(session, new Request.GraphUserCallback() {

                    @Override
                    public void onCompleted(GraphUser user, Response response) {
                        if(user != null) {
                            Log.i(TAG, "User ID " + user.getId());
                            Log.i(TAG, "Email " + user.asMap().get("email"));
                            lblEmail.setText(user.asMap().get("email").toString());
                        }
                    }
                });
            }
        }
    });
}

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.main, menu);
        return true;
    }

}

И мой вывод logcat:https://www.dropbox.com/s/7qg9zbhlpikfovf/log.txt

Ответы на вопрос(4)

Ваш ответ на вопрос