11

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

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

我已经在 stackoverflow 上看到了这些解决方案(解决方案 1解决方案 2),但我仍然不知道从哪里开始?

更新 1 ::

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

如果您不知道从哪里开始,请按照步骤 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

4 回答 4

8

使用 Facebook SDK 管理用户身份验证的更好方法是通过Session类。当您拥有 Session 类的有效实例时,您只需调用getAccessToken()它即可获取表示访问令牌的字符串。

Session session = Session.getActiveSession();
if (session != null && session.getState().isOpened()){
     Log.i("sessionToken", session.getAccessToken());
     Log.i("sessionTokenDueDate", session.getExpirationDate().toLocaleString());
}
于 2013-05-02T14:05:56.397 回答
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();
于 2015-04-16T19:12:27.497 回答
1

获取/oauth/access_token?client_id={app-id} &client_secret={app-secret} &grant_type=client_credentials

于 2014-01-17T22:12:41.240 回答
0

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

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

于 2013-05-03T02:21:21.020 回答