Android + Facebook + onComplete()方法的'response'参数

时间:2011-11-03 16:06:45

标签: android facebook

fb android sdk doc提供了这个引用:

“但请注意,这并未考虑用户可能已撤销对您应用的访问权限或用户更改了密码的情况。您需要始终注意无效的access_token并重定向用户以重新启用授权您的应用。对于无效访问令牌,onComplete()方法的'response'参数中会返回以下错误:“

文档提供了一个共享首选项解决方案,可在用户每次启动应用时隐藏“OKAY”页面。但是,如果用户更改其密码或从fb应用程序本身注销,我的应用程序(由于设置了共享首选项)忽略登录对话框,因为不调用facebook.authorize()。鉴于在文档上找到的实现,当再次调用onComplete()时,如何监听access_token错误。

package com.greatapp;

import android.app.Activity;
import android.content.Intent;
import android.content.SharedPreferences;
import android.os.Bundle;
import com.facebook.android.*;
import com.facebook.android.Facebook.*;

public class MyGreatActivity extends Activity {

    Facebook facebook = new Facebook("YOUR_APP_ID");
    String FILENAME = "AndroidSSO_data";
    private SharedPreferences mPrefs;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        /*
         * Get existing access_token if any
         */
        mPrefs = getPreferences(MODE_PRIVATE);
        String access_token = mPrefs.getString("access_token", null);
        long expires = mPrefs.getLong("access_expires", 0);
        if(access_token != null) {
            facebook.setAccessToken(access_token);
        }
        if(expires != 0) {
            facebook.setAccessExpires(expires);
        }

        /*
         * Only call authorize if the access_token has expired.
         */
        if(!facebook.isSessionValid()) {

            facebook.authorize(this, new String[] {}, new DialogListener() {
                @Override
                public void onComplete(Bundle values) {
                    SharedPreferences.Editor editor = mPrefs.edit();
                    editor.putString("access_token", facebook.getAccessToken());
                    editor.putLong("access_expires", facebook.getAccessExpires());
                    editor.commit();
                }

                @Override
                public void onFacebookError(FacebookError error) {}

                @Override
                public void onError(DialogError e) {}

                @Override
                public void onCancel() {}
            });
        }
    }

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

        facebook.authorizeCallback(requestCode, resultCode, data);
    }
}

1 个答案:

答案 0 :(得分:4)

如果你想保留你的app结构(使用Preferences来获取access_token而不必每次都进行用户登录),那么你只会发现当你真正尝试使用API​​时access_token是无效的。例如,如果您在令牌无效时发送GRAPH API请求,SDK将发送如下内容。

https://graph.facebook.com/me?access_token=invalid_access_token

将返回以下JSON(非常清楚)。

{
   "error": {
      "message": "Invalid OAuth access token.",
      "type": "OAuthException"
   }
}

此时您将知道您需要进行授权()。