我使用3.0文档中的步骤构建了Facebook集成。当我使用Eclispe将应用程序部署到手机时,它可以正常工作;但是,当我导出应用程序将其上传到商店并侧面加载apk时,它会失败,并显示以下错误。当我导出它时,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);
}
};
}
编辑:--------------------------------------------- -
以下是我的尝试:
我已经尝试了所有可以在互联网上找到的东西,但无法弄清楚问题是什么。
答案 0 :(得分:53)
FacebookSdk.sdkInitialize(getApplicationContext());
这在setContentView
之前 setContentView(R.layout.activity_home);
答案 1 :(得分:11)
如果您使用的是Facebook SDK 4.x,请注意包名称已更改。它现在是com.facebook.login.widget.LoginButton
答案 2 :(得分:4)
我遇到了同样的错误,我刚刚清理了我的项目(facebook sdk和当前项目)并且已经解决了。
答案 3 :(得分:4)
你必须在setContentView之前初始化facebook SDK,所以在setContentView正上方添加以下行
FacebookSdk.sdkInitialize(getApplicationContext());
答案 4 :(得分:3)
将Facebook添加为模块后,您必须将其添加到Gradle中的依赖项中,将下一行添加到依赖项块中:
compile project(':facebook')
我希望它可以提供帮助。
答案 5 :(得分:1)
我发现修复此问题的唯一方法是将整个SDK放入我的项目中。现在它有效。不是首选的解决方案,但它确实有效。
答案 6 :(得分:1)
即使我试图在模拟器中运行它,我也有同样的错误。
我的问题更加相关,我将Facebook Sdk添加到构建路径,而不是在“属性”选项卡中添加项目。我从another stackoverflow answer
得到了答案答案 7 :(得分:1)
刚刚初始化FacebookSdk.sdkInitialize(getApplicationContext());在您的Application类中。因为Application类甚至在您的活动初始化之前就已初始化。
就像这样:
public class ApplicationController扩展Application {
@Override
public void onCreate() {
super.onCreate();
FacebookSdk.sdkInitialize(getApplicationContext());
}
}
答案 8 :(得分:0)
一种解决方案是将Facebook SDK的路径添加到项目中的“project.properties”。
像:
android.library.reference.1=../libfacebook/facebook-android-sdk-3.0.1/facebook
答案 9 :(得分:0)
我也有同样的错误,只是通过android-support-v4.jar与android-support-v13.jar关联解决问题。
答案 10 :(得分:0)
以防万一..如果有人还需要它,只清理facebook项目,然后将其作为库添加回项目中。这解决了我的问题
答案 11 :(得分:0)
我尝试以编程方式创建LoginButton的实例,以编程方式
itemsArray[n][name]
并将其添加到 LinearLayout
Item 2
这是我的布局xml的一瞥
LoginButton loginButton = new LoginButton(this);
这是@Lalit Kumar's answer建议的编辑之后 如果我错过任何东西,请告诉我。
答案 12 :(得分:0)
如果您将facebook库添加到Properties-&gt; Android的应用程序中,则应删除facebooksdk路径/ bin / facebook.jar中的facebook.jar。在eclipse中链接时会导致错误。然后你清理你的Facebook sdk和你的应用程序。我希望能正常工作。