为什么“Facebook SDK for Android入门”示例不起作用?

时间:2013-12-19 16:33:35

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

我正在尝试创建我的第一个Facebook Android应用程序,但它不起作用。

https://developers.facebook.com/docs/android/getting-started/

它不会在“hello word”字符串中打印我的名字,而app会进入无限循环。

主类

package com.firstandroidappalf;

import android.os.Bundle;
import android.app.Activity;
import android.content.Intent;
import android.widget.TextView;
import com.facebook.*;
import com.facebook.model.*;

public class MainActivity extends Activity {

@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

// 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() + "!");
          }
        }
      });
    }
  }
});
}

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

}

清单

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.firstandroidappalf"
android:versionCode="1"
android:versionName="1.0" >

<uses-sdk
    android:minSdkVersion="8"
    android:targetSdkVersion="18" />
<uses-permission android:name="android.permission.INTERNET"/>

<application
    android:allowBackup="true"
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name"
    android:theme="@style/AppTheme" >
    <activity
        android:name="com.firstandroidappalf.MainActivity"
        android:label="@string/app_name" >
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
    <meta-data android:value="@string/app_id" android:name="com.facebook.sdk.ApplicationId"/>
    <activity android:name="com.facebook.LoginActivity"></activity>
</application>

String resourc

<string name="app_name">First Android App</string>
<string name="action_settings">Settings</string>
<string name="hello_world">Hello world!</string>
 <string name="app_id">6427XXXX9097984</string>

keyhashes

http://www.easyfacebookandroidsdk.com/download/keyhash.zip

记录cat错误:

12-19 17:16:19.870:E / SpannableStringBuilder(19027):SPAN_EXCLUSIVE_EXCLUSIVE跨度不能为零长度 12-19 17:16:19.870:E / SpannableStringBuilder(19027):SPAN_EXCLUSIVE_EXCLUSIVE跨度不能为零长度 12-19 17:36:19.785:E / SpannableStringBuilder(19027):SPAN_EXCLUSIVE_EXCLUSIVE跨度不能为零长度 12-19 17:36:19.785:E / SpannableStringBuilder(19027):SPAN_EXCLUSIVE_EXCLUSIVE跨度不能为零长度

facebook dev

1 个答案:

答案 0 :(得分:0)

1天后我解决了。 问题是关于安卓开发人员的关键问题因为使用openssl创建的keyhash或http://www.easyfacebookandroidsdk.com/download/keyhash.zip中的工具是错误的。

我的正确解决方案如下,但有关此问题的更多信息,请查看

<{3}}

中的

疑难解答部分

//imports:

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import android.os.Bundle;
import android.app.Activity;
import android.content.Intent;
import android.content.pm.PackageInfo;
import android.content.pm.PackageManager;
import android.content.pm.PackageManager.NameNotFoundException;
import android.content.pm.Signature;
import android.util.Base64;
import android.util.Log;
import android.widget.TextView;
import com.facebook.*;
import com.facebook.model.*;

@Override
 public void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);


    try {
       **//be careful to put the correct package name, it was mmy first mistake**
       PackageInfo info = getPackageManager().getPackageInfo("[your package name, e.g.    com.yourcompany.yourapp]", PackageManager.GET_SIGNATURES);
       for (Signature signature : info.signatures) {
           MessageDigest md = MessageDigest.getInstance("SHA");
           md.update(signature.toByteArray());
           Log.d("Hash Key:","Hash Key " +Base64.encodeToString(md.digest(), Base64.DEFAULT));

        }
        } catch (NameNotFoundException e) {

        } catch (NoSuchAlgorithmException e) {

    }
   ...
  }

在Logcat的消息中找到“Hash Key:”,找到正确的keyhash。