Android:Facebook 登录不起作用
Posted
技术标签:
【中文标题】Android:Facebook 登录不起作用【英文标题】:Android: Facebook Login doesn't work 【发布时间】:2012-10-24 12:35:26 【问题描述】:我在这里使用这个简单的代码:
https://developers.facebook.com/docs/mobile/android/build/#sig
public class MainActivity extends Activity
Facebook facebook = new Facebook("xxxxxxxxxxxxxx");
AsyncFacebookRunner mAsyncRunner = new AsyncFacebookRunner(facebook);
private SharedPreferences mPrefs;
@Override
public void onCreate(Bundle savedInstanceState)
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
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);
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);
try
JSONObject json = Util.parseJson(facebook.request("me"));
String facebookID = json.getString("id");
String firstName = json.getString("first_name");
String lastName = json.getString("last_name");
String email = json.getString("email");
String gender = json.getString("gender");
catch (Exception e)
//If i click Okay i get Exception saying You need an Active access token to get the current user details
使用这个得到哈希键:
要求输入密码(“android”)
并给我这样的代码:
xLYMxxxxxx/0enePexxf4DORUfR8=
在 facebook 应用程序中我的配置是:
但我得到这个错误:
如果我按下 Okay,我会收到一条异常消息,提示您需要一个 Active 访问令牌才能获取当前用户详细信息。
我尝试了 SOF 上给出的所有可能的解决方案。但是没有用。请帮忙
谢谢
【问题讨论】:
查看 com.facebook.android.Utils 类代码。设置私有静态布尔 ENABLE_LOG = true;并在您尝试登录时观察 LogCat 输出。 是的。它总是正确的,并且从未在 logcat 中向我显示任何内容。 :( 我也有“登录配置错误”错误。一段时间后,由于某种原因,Facebook 想要与我不同的 keyhash。 你是怎么得到新的哈希键的?? 经过一段时间的调试后,它出现在 LogCat 输出中;/类似这样的“登录失败:invalid_key:Android 密钥不匹配。您的密钥“XXXXXXXXXXXXXXX”与您的应用程序中指定的允许密钥不匹配设置。在facebook.com/developers检查您的应用程序设置“我会亲自将JSON解析放入LoginListener。并将 Logs 放入 Listner 中的 onFacebookError 和 onError 中,看看你是否从这里得到任何错误。 【参考方案1】:您似乎没有从终端正确获取哈希密钥。
试试这个
-
通过转到 Facebook SDK 源
Util.java
并将 ENABLE_LOG
设置为 true 来启用日志记录。
再次尝试登录您的应用程序,您应该仍会看到红色错误消息。按确定。
转到您的 logcat 并找到如下所示的条目:
D/Facebook-authorize(24739):登录失败:invalid_key:Android 密钥不匹配。您的密钥“uk3udeH7vrOGNFH2FJjdJbdWJWI”与您的应用程序设置中指定的允许密钥不匹配。在http://www.facebook.com/developers检查您的应用程序设置
将该密钥复制并粘贴到您的信息中心,然后重试。
查看这个 SO 线程:App is misconfigured for Facebook login : Android Facebook integration issue
【讨论】:
问题是:logcat 没有显示任何错误。但是经过几次重新启动后,我终于得到了您粘贴的错误。但我有一个疑问。除了我在配置中使用的散列键末尾的 = 之外,错误给出的 has 键是相同的。那么我应该删除那个 = 吗?谢谢 不,您应该准确地粘贴它所说的内容。 = 符号是密钥哈希的一部分 哎呀。但它只能在没有 = 的情况下工作。我应该使用我在终端中使用 keytool 获得的 1 还是我在 logcat 错误消息中获得的 1?? 保证 logcat 错误消息中的那个是正确的哈希,而如果您的设置不正确,keytool 命令可能会返回错误的,所以我会选择错误消息中的那个 ENABLE_LOG 自 2012 年 12 月起无法再更改:github.com/facebook/facebook-android-sdk/commit/…以上是关于Android:Facebook 登录不起作用的主要内容,如果未能解决你的问题,请参考以下文章
Facebook 登录在 Android 应用程序浏览器中的 Facebook 中不起作用
已安装 Facebook 应用程序时,Android 中的 Facebook 集成不起作用