我正在使用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() + "!");
}
}
});
}
}
});
}
}
答案 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输入。但它只适用于管理员用户。
实际上在应用创建过程中,我错误地选择了“沙盒”模式,该模式限制了应用只能访问应用配置页面中添加的开发人员。因此,在禁用此模式后,我也能够为其他用户生成访问令牌。