2013-12-19 36 views
2

我想创建我的第一个Facebook Android应用程序,但它不起作用。为什么“开始使用Facebook SDK for Android”示例不起作用?

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

它不会在“你好词”字符串打印我的名字和应用程序在一个无限循环进入。

主类

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> 

字符串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

登录猫错误:

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

+0

定义“不起作用”。它是如何工作的。什么失败了,你看到了什么?您是否已经在调试器中逐步了解代码,以确切了解什么是失败,以及变量的值是否与您期望的一致? –

+0

好吧!我在做 –

+0

我会把if(session.isOpened())和if(user!= null)的断点放到开始位置。 –

回答

0

1天后我解决。 问题是keyhash放在Android开发者上,因为使用openssl创建的keyhash或者http://www.easyfacebookandroidsdk.com/download/keyhash.zip中的工具是错误的。

我正确的解决办法是低于但有关此问题的更多信息,你可以看看

故障排除部分https://developers.facebook.com/docs/android/login-with-facebook/

//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中的邮件,你找到了正确的keyhash 。

相关问题