如何在android中获取facebook用户访问令牌?

时间:2013-05-02 04:27:26

标签: android facebook-graph-api facebook-android-sdk

我正在使用restfb API访问我朋友的Java照片。为了访问这些照片,我使用Graph API explorer手动生成访问代码,并将其作为参数传递给restfb API调用。

但现在我想通过代码(以编程方式)生成此访问令牌。我见过fb android示例,尤其是hackbook。我没有看到生成任何访问代码,我可以将其用于我自己的应用程序。我是否需要创建一个新的应用程序并获得一些秘密等?任何建议将不胜感激。

我已经在stackoverflow上看到了这些解决方案(solution-1& solution-2),但我仍然无法从哪里开始?

更新-1 ::

我正在使用以下代码登录并获取登录用户的访问令牌。但问题是它只适用于我在facebook上创建应用程序以生成app_id的帐户。它没有收到其他帐户的回电。有任何建议请。

如果您不知道从哪里开始,请按照step-6从头开始创建新应用。

public class MainActivity extends Activity implements OnClickListener {

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

        login = (Button) findViewById(R.id.login);
        accessToken = (TextView) findViewById(R.id.accessToken);

        login.setOnClickListener(this);
        // start Facebook Login


    }

    @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;
    }

    @Override
    public void onActivityResult(int requestCode, int resultCode, Intent data) {
      super.onActivityResult(requestCode, resultCode, data);
      Session.getActiveSession().onActivityResult(this, requestCode, resultCode, data);
    }

    @Override
    public void onResume()
    {
         Session session = Session.getActiveSession();
         if(session != null)
            if (session.isOpened()) {
                //Toast.makeText(this, session.getAccessToken(), Toast.LENGTH_LONG).show();
                accessToken = (TextView) findViewById(R.id.accessToken);
                accessToken.setText(session.getAccessToken());
                System.out.println("----------------------" + session.getAccessToken() + "---------------------");

            }
        super.onResume();
    }

    @Override
    public void onClick(View v) {
        // start Facebook Login
        Session.openActiveSession(this, true, new Session.StatusCallback() {

            // callback when session changes state
            @Override
            public void call(Session session, SessionState state,
                    Exception exception) {
                if (session.isOpened()) {

                    // make request to the /me API
                    Request.executeMeRequestAsync(session,
                            new Request.GraphUserCallback() {

                                // callback after Graph API response with user
                                // object
                                @Override
                                public void onCompleted(GraphUser user,
                                        Response response) {
                                    if (user != null) {
                                        TextView welcome = (TextView) findViewById(R.id.welcome);
                                        welcome.setText("Hello "
                                                + user.getName() + "!");
                                    }
                                }
                            });
                }
            }
        });

    }

    }

4 个答案:

答案 0 :(得分:8)

使用Facebook SDK,管理用户身份验证的更好方法是使用Session类。 当你有一个有效的Session类实例时,你只需调用它上面的getAccessToken()就可以获得代表访问令牌的String。

Session session = Session.getActiveSession();
if (session != null && session.getState().isOpened()){
     Log.i("sessionToken", session.getAccessToken());
     Log.i("sessionTokenDueDate", session.getExpirationDate().toLocaleString());
}

答案 1 :(得分:8)

使用最新的Facebook Android SDK(4.0.1)时遇到了同样的问题。

我使用了AccessToken.getCurrentAccessToken()并且它起作用了:

    GraphRequest request = GraphRequest.newMeRequest(
            AccessToken.getCurrentAccessToken(),
            new GraphRequest.GraphJSONObjectCallback() {
                @Override
                public void onCompleted(JSONObject jsonObject, GraphResponse response) {
                    Log.d(LOG_TAG,"onCompleted jsonObject: "+jsonObject);
                    Log.d(LOG_TAG,"onCompleted response: "+response);
                    // Application code
                }
            });
    Bundle parameters = new Bundle();
    parameters.putString("fields", "id,name,link,cover,email");
    request.setParameters(parameters);
    request.executeAsync();

答案 2 :(得分:1)

GET / oauth / access_token?      CLIENT_ID = {应用ID}     &安培; client_secret = {应用秘密}     &安培; grant_type = client_credentials

答案 3 :(得分:0)

原始问题的答案已作为update-1输入。但它只适用于管理员用户。

实际上在应用创建过程中,我错误地选择了“沙盒”模式,该模式限制了应用只能访问应用配置页面中添加的开发人员。因此,在禁用此模式后,我也能够为其他用户生成访问令牌。