16

3.0ドキュメントの手順を使用してFacebook統合を構築しました。Eclispeを使用してアプリを携帯電話にデプロイすると、正常に機能します。ただし、アプリをエクスポートしてストアにアップロードし、apkをサイドロードすると、次のエラーで失敗します。SDKをエクスポートすると、SDKがそこにあり、ロードされます。私がどこで間違っているのかについての手がかりはありますか?

03-18 21:01:02.089: E/AndroidRuntime(14834): FATAL EXCEPTION: main
03-18 21:01:02.089: E/AndroidRuntime(14834): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.telvista.facebooksupport/com.telvista.facebooksupport.SplashActivity}: android.view.InflateException: Binary XML file line #51: Error inflating class com.facebook.widget.LoginButton
03-18 21:01:02.089: E/AndroidRuntime(14834):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2088)
03-18 21:01:02.089: E/AndroidRuntime(14834):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2113)
03-18 21:01:02.089: E/AndroidRuntime(14834):    at android.app.ActivityThread.access$700(ActivityThread.java:139)
03-18 21:01:02.089: E/AndroidRuntime(14834):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1224)
03-18 21:01:02.089: E/AndroidRuntime(14834):    at android.os.Handler.dispatchMessage(Handler.java:99)
03-18 21:01:02.089: E/AndroidRuntime(14834):    at android.os.Looper.loop(Looper.java:137)
03-18 21:01:02.089: E/AndroidRuntime(14834):    at android.app.ActivityThread.main(ActivityThread.java:4918)
03-18 21:01:02.089: E/AndroidRuntime(14834):    at java.lang.reflect.Method.invokeNative(Native Method)
03-18 21:01:02.089: E/AndroidRuntime(14834):    at java.lang.reflect.Method.invoke(Method.java:511)
03-18 21:01:02.089: E/AndroidRuntime(14834):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1004)
03-18 21:01:02.089: E/AndroidRuntime(14834):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:771)
03-18 21:01:02.089: E/AndroidRuntime(14834):    at dalvik.system.NativeStart.main(Native Method)
03-18 21:01:02.089: E/AndroidRuntime(14834): Caused by: android.view.InflateException: Binary XML file line #51: Error inflating class com.facebook.widget.LoginButton
03-18 21:01:02.089: E/AndroidRuntime(14834):    at android.view.LayoutInflater.createView(LayoutInflater.java:613)
03-18 21:01:02.089: E/AndroidRuntime(14834):    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:687)
03-18 21:01:02.089: E/AndroidRuntime(14834):    at android.view.LayoutInflater.rInflate(LayoutInflater.java:746)
03-18 21:01:02.089: E/AndroidRuntime(14834):    at android.view.LayoutInflater.rInflate(LayoutInflater.java:749)
03-18 21:01:02.089: E/AndroidRuntime(14834):    at android.view.LayoutInflater.inflate(LayoutInflater.java:489)
03-18 21:01:02.089: E/AndroidRuntime(14834):    at android.view.LayoutInflater.inflate(LayoutInflater.java:396)
03-18 21:01:02.089: E/AndroidRuntime(14834):    at android.view.LayoutInflater.inflate(LayoutInflater.java:352)
03-18 21:01:02.089: E/AndroidRuntime(14834):    at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:306)
03-18 21:01:02.089: E/AndroidRuntime(14834):    at android.app.Activity.setContentView(Activity.java:1901)
03-18 21:01:02.089: E/AndroidRuntime(14834):    at com.telvista.facebooksupport.SplashActivity.onCreate(SplashActivity.java:29)
03-18 21:01:02.089: E/AndroidRuntime(14834):    at android.app.Activity.performCreate(Activity.java:5048)
03-18 21:01:02.089: E/AndroidRuntime(14834):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1094)
03-18 21:01:02.089: E/AndroidRuntime(14834):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2052)
03-18 21:01:02.089: E/AndroidRuntime(14834):    ... 11 more
03-18 21:01:02.089: E/AndroidRuntime(14834): Caused by: java.lang.reflect.InvocationTargetException
03-18 21:01:02.089: E/AndroidRuntime(14834):    at java.lang.reflect.Constructor.constructNative(Native Method)
03-18 21:01:02.089: E/AndroidRuntime(14834):    at java.lang.reflect.Constructor.newInstance(Constructor.java:417)
03-18 21:01:02.089: E/AndroidRuntime(14834):    at android.view.LayoutInflater.createView(LayoutInflater.java:587)
03-18 21:01:02.089: E/AndroidRuntime(14834):    ... 23 more
03-18 21:01:02.089: E/AndroidRuntime(14834): Caused by: java.lang.NoClassDefFoundError: com.facebook.android.R$color
03-18 21:01:02.089: E/AndroidRuntime(14834):    at com.facebook.widget.LoginButton.<init>(LoginButton.java:204)
03-18 21:01:02.089: E/AndroidRuntime(14834):    ... 26 more

マニフェストは次のとおりです。

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

    <uses-sdk
    android:minSdkVersion="11"
    android:targetSdkVersion="17" />
    <uses-permission android:name="android.permission.INTERNET"/>
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

    <application
    android:allowBackup="false"
    android:icon="@drawable/t_logo"
    android:label="@string/app_name">

    <activity
        android:theme="@android:style/Theme.NoTitleBar"
        android:name="com.t.facebooksupport.SplashActivity"
        android:icon="@drawable/t_logo"
        android:label="@string/app_name" >
        <intent-filter>
        <action android:name="android.intent.action.MAIN" />

        <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
    <activity
        android:name="com.t.facebooksupport.MainActivity">
    </activity>
    <activity
        android:name="com.t.facebooksupport.ViewPost">
    </activity>
    <meta-data android:name="com.facebook.sdk.ApplicationId" android:value="@string/app_id"/>
    <activity android:label="@string/app_name" android:name="com.facebook.LoginActivity"></activity>

    </application>

</manifest>

ログインボタン付きのスプラッシュページ:

package com.t.facebooksupport;

import java.util.Arrays;
import java.util.Map;

import com.facebook.Request;
import com.facebook.Response;
import com.facebook.Session;
import com.facebook.SessionState;
import com.facebook.UiLifecycleHelper;
import com.facebook.model.GraphUser;
import com.facebook.widget.LoginButton;
import com.t.facebooksupport.helper.PostConstants;

import android.app.Activity;
import android.content.Intent;
import android.content.SharedPreferences;
import android.os.Bundle;
import android.util.Log;

public class SplashActivity extends Activity {

    private UiLifecycleHelper uiHelper;
    private boolean isResumed = false;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.splash);

        uiHelper = new UiLifecycleHelper(this, callback);
        Session session = Session.getActiveSession();

        if (session != null && session.isOpened()) {
            startActivity(new Intent(SplashActivity.this, MainActivity.class));
        }
        LoginButton authButton = (LoginButton) findViewById(R.id.login_button);
        authButton.setReadPermissions(Arrays.asList("email"));

    }

    private void onSessionStateChange(Session session, SessionState state, Exception exception) {
        if (isResumed) {
            if (state.isOpened()) {
                Request.executeMeRequestAsync(session, new Request.GraphUserCallback() {

                    @Override
                    public void onCompleted(GraphUser user, Response response) {
                        if (user != null) {
                            // Display the parsed user info
                            SharedPreferences settings = getSharedPreferences(PostConstants.PREFS_NAME, Activity.MODE_PRIVATE);
                            SharedPreferences.Editor editor = settings.edit();
                            editor.putString("fb_id", user.getId());
                            editor.putString("fullname", user.getFirstName() + " " + user.getLastName());
                            editor.putString("firstname", user.getFirstName());
                            editor.putString("lastname", user.getLastName());
                            editor.putString("image_loc", "https://graph.facebook.com/" + user.getId() + "/picture?type=large");
                            editor.putString("user_id", user.asMap().get("email").toString());
                            editor.putString("email", user.asMap().get("email").toString());
                            editor.putString("page", "1");
                            editor.putString("count", "30");
                            editor.putString("token", "");
                            editor.commit();

                            startActivity(new Intent(SplashActivity.this, MainActivity.class));
                        }
                    }
                });
            } else if (state.isClosed()) {
            }
        }
    }

    @Override
    public void onResume() {
        super.onResume();
        uiHelper.onResume();
        isResumed = true;
    }

    @Override
    public void onPause() {
        super.onPause();
        uiHelper.onPause();
        isResumed = false;
    }

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

    @Override
    public void onDestroy() {
        super.onDestroy();
        uiHelper.onDestroy();
    }

    @Override
    protected void onSaveInstanceState(Bundle outState) {
        super.onSaveInstanceState(outState);
        uiHelper.onSaveInstanceState(outState);
    }

    private Session.StatusCallback callback = new Session.StatusCallback() {
        @Override
        public void call(Session session, SessionState state, Exception exception) {
            onSessionStateChange(session, state, exception);
        }
    };

}

編集: - - - - - - - - - - - - - - - - - - - - - - - -

これが私が試したことです:

  1. 私のプロジェクトとFacebookSDKの両方を約50回クリーニングしてみました。
  2. FacebookSDKを削除し、3回再読み込みしました。

私はインターネットで見つけることができるすべてを試しましたが、問題が何であるかを理解できません。

4

14 に答える 14

55

FacebookSdk.sdkInitialize(getApplicationContext());

setContentViewの前にこれ

  setContentView(R.layout.activity_home);
于 2015-07-23T10:10:50.197 に答える
11

Facebook SDK 4.xを使用している場合は、パッケージ名が変更されていることに注意してください。雪が降るcom.facebook.login.widget.LoginButton

于 2015-06-11T15:46:58.233 に答える
6

sdkInitializeの前にコンテンツビューを設定したため、このエラーが発生していました。スタートガイドには、これを参照するコメントがあります。

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

@Override
 public void onCreate(Bundle savedInstanceState) {
     super.onCreate(savedInstanceState);
     FacebookSdk.sdkInitialize(getApplicationContext());
     // Initialize the SDK before executing any other operations,
     // especially, if you're using Facebook UI elements.
}

したがって、私のコードは次のようになります。

@Override
 public void onCreate(Bundle savedInstanceState) {
     super.onCreate(savedInstanceState);
     FacebookSdk.sdkInitialize(getApplicationContext());
     setContentView(R.layout.activity_main);
}
于 2015-08-16T09:56:34.790 に答える
4

同じエラーが発生しました。プロジェクト(Facebook SDKと現在のプロジェクト)をクリーンアップしたところ、解決されました。

于 2013-09-16T14:13:01.973 に答える
4

setContentViewの前にFacebookSDKを初期化する必要があるため、setContentViewのすぐ上に次の行を追加します

FacebookSdk.sdkInitialize(getApplicationContext());
于 2016-05-13T08:36:26.597 に答える
3

Facebookをモジュールとして追加した後、それをGradleの依存関係に追加し、次の行を依存関係ブロックに追加する必要があります。

compile project(':facebook')

お役に立てば幸いです。

于 2014-09-30T14:01:15.897 に答える
1

これを修正する唯一の方法は、SDK全体をプロジェクトに組み込むことでした。今では動作します。推奨されるソリューションではありませんが、機能します。

于 2013-03-19T15:30:12.223 に答える
1

エミュレータで実行しようとしても同じエラーが発生しました。

私の問題は、[プロパティ]タブでプロジェクトを追加する代わりに、FacebookSdkをビルドパスに追加したことに関連していました。私は別のstackoverflowの答えから答えを得ました

于 2013-09-04T23:07:03.030 に答える
1

FacebookSdk.sdkInitialize(getApplicationContext());を初期化するだけです。Applicationクラスで。アプリケーションクラスは、アクティビティが初期化される前でも初期化されるためです。

このようにしてください:

パブリッククラスApplicationControllerはApplication{を拡張します

@Override
public void onCreate() {
    super.onCreate();
    FacebookSdk.sdkInitialize(getApplicationContext());
}

}

于 2015-06-20T08:51:55.740 に答える
0

1つの解決策は、FacebookSDKのパスをプロジェクトの「project.properties」に追加することです。

好き:

android.library.reference.1=../libfacebook/facebook-android-sdk-3.0.1/facebook
于 2013-07-05T06:58:45.737 に答える
0

同じエラーが発生し、android-support-v4.jarをandroid-support-v13.jarに置き換えるだけで問題が解決しました。

于 2014-02-07T07:54:21.653 に答える
0

念のため..誰かがまだそれを必要としている場合は、Facebookプロジェクトのみをクリーンアップしてから、プロジェクトのライブラリとして追加し直してください。これは私の問題を解決しました

于 2014-09-04T18:40:28.517 に答える
0

LoginButtonのインスタンスをプログラムで作成してみました

LoginButton loginButton = new LoginButton(this);

これをLinearLayoutに追加しました

    fbLoginButton = (LinearLayout) findViewById(R.id.fb_login_view);
    fbLoginButton.addView(loginButton);

そして、これが私のレイアウトxmlの概要です

<LinearLayout
            android:layout_width="wrap_content"
            android:layout_height="40dip"
            android:id="@+id/fb_login_view"
            android:layout_centerInParent="true"
            android:layout_gravity="center_horizontal"
            android:text="connect_with_facebook"/>

これはもちろん、@LalitKumarの回答によって提案された編集に続く ものです。何か足りないものがあれば教えてください。

于 2015-10-29T20:12:25.947 に答える
0

[プロパティ]->[Android]でアプリケーションにFacebookライブラリを追加する場合は、facebooksdk path / bin/facebook.jarのfacebook.jarを削除する必要があります。Eclipseでリンクするとエラーが発生します。次に、FacebookSDKとアプリケーションをクリーンアップします。私はうまくいくことを願っています。

于 2015-11-10T14:00:16.157 に答える