本机模块 FBAccessToken 试图覆盖 FBAccessTokenModule。检查 MainApplication.Java 中的 getPackages() 方法

Native module FBAccessToken tried to override FBAccesTokenModule. Check the getPackages() method in MainApplication.Java

所以我在尝试将 Facebook 登录集成到我的应用程序时收到此错误消息,但总体上不清楚如何解决它,因为我似乎无法弄清楚我的 MainActivity.java 文件有什么问题。我已经使用“npm install --save react-native-fbsdk-next”安装了 Facebook SDK,总体上似乎具有必要且正确的依赖项。

The error message

我的 MainActivity.Java 文件中的代码:

package com.socialapp2;

import android.app.Application;
import android.content.Context;
import com.facebook.react.PackageList;
import com.facebook.react.ReactApplication;
import com.facebook.react.ReactInstanceManager;
import com.facebook.react.ReactNativeHost;
import com.facebook.react.ReactPackage;
import com.facebook.soloader.SoLoader;
import java.lang.reflect.InvocationTargetException;
import java.util.List;

public class MainApplication extends Application implements ReactApplication {

  private final ReactNativeHost mReactNativeHost = new ReactNativeHost(this) {
    @Override
    public boolean getUseDeveloperSupport() {
      return BuildConfig.DEBUG;
    }

    @Override
    protected List<ReactPackage> getPackages() {
      @SuppressWarnings("UnnecessaryLocalVariable")
      List<ReactPackage> packages = new PackageList(this).getPackages();
      // Packages that cannot be autolinked yet can be added manually here, for
      // example:
      // packages.add(new MyReactNativePackage());
      return packages;
    }

    @Override
    protected String getJSMainModuleName() {
      return "index";
    }
  };

  @Override
  public ReactNativeHost getReactNativeHost() {
    return mReactNativeHost;
  }

  @Override
  public void onCreate() {
    super.onCreate();
    SoLoader.init(this, /* native exopackage */ false);
    initializeFlipper(this, getReactNativeHost().getReactInstanceManager());
  }

  /**
   * Loads Flipper in React Native templates. Call this in the onCreate method
   * with something like initializeFlipper(this,
   * getReactNativeHost().getReactInstanceManager());
   *
   * @param context
   * @param reactInstanceManager
   */
  private static void initializeFlipper(Context context, ReactInstanceManager reactInstanceManager) {
    if (BuildConfig.DEBUG) {
      try {
        /*
         * We use reflection here to pick up the class that initializes Flipper, since
         * Flipper library is not available in release mode
         */
        Class<?> aClass = Class.forName("com.socialapp.ReactNativeFlipper");
        aClass.getMethod("initializeFlipper", Context.class, ReactInstanceManager.class).invoke(null, context,
            reactInstanceManager);
      } catch (ClassNotFoundException e) {
        e.printStackTrace();
      } catch (NoSuchMethodException e) {
        e.printStackTrace();
      } catch (IllegalAccessException e) {
        e.printStackTrace();
      } catch (InvocationTargetException e) {
        e.printStackTrace();
      }
    }
  }
}

我解决了这个问题。请参阅下面的解决方案:

  • 检查您的 package.json 文件并确保您没有重复的 facebook sdk 依赖项。在我的例子中,我将“react-native-fbsdk”和“react-native-fbsdk-next”作为两个相互冲突的独立依赖项。

下面还有一些常规故障排除步骤:

  • 确保 MainActivity.java、MainApplication.java 和 AndroidManifest.xml 文件中的软件包名称相同。

  • 确保 app/build.gradle 文件中的 applicatonId 与上一个要点中指定的程序包名称匹配。