2013-12-19 1 views
2

Я пытаюсь создать свое первое приложение Android для Android, но оно не работает.Почему «Начать работу с Facebook SDK для 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); 
} 

} 

Manifest

<?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 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: Е/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, потому что keyhash, созданный с помощью openssl или инструмента в 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 ,

 Смежные вопросы

  • Нет связанных вопросов^_^