OneSignal Android Studio 获取 FCM 令牌时发生未知错误
OneSignal Android Studio Unknown error getting FCM Token
我有一个问题。
我无法使用 OneSignal。我不知道为什么。我用谷歌搜索了这个错误,但没有任何帮助。
目前我使用 Android Studio 版本:4.2
OneSignal最新版本:4.3.4
还有最新的 Firebase 版本。我创建了一个新的 Firebase 项目和 OneSignal 项目。
这是错误:
2021-05-25 13:06:37.370 3225-4181/de.kggaming.application E/OneSignal: Unknown error getting FCM Token
java.lang.NoClassDefFoundError: Failed resolution of: Lcom/google/firebase/iid/FirebaseInstanceId;
at com.onesignal.PushRegistratorFCM.getToken(PushRegistratorFCM.java:60)
at com.onesignal.PushRegistratorAbstractGoogle.attemptRegistration(PushRegistratorAbstractGoogle.java:97)
at com.onesignal.PushRegistratorAbstractGoogle.access0(PushRegistratorAbstractGoogle.java:37)
at com.onesignal.PushRegistratorAbstractGoogle.run(PushRegistratorAbstractGoogle.java:84)
at java.lang.Thread.run(Thread.java:923)
Caused by: java.lang.ClassNotFoundException: Didn't find class "com.google.firebase.iid.FirebaseInstanceId" on path: DexPathList[[dex file "/data/data/de.kggaming.application/code_cache/.overlay/base.apk/classes3.dex", zip file "/data/app/~~37wP-zifceloViDoIaZiLQ==/de.kggaming.application-MT0rnPML9HHvlPgijekxXw==/base.apk"],nativeLibraryDirectories=[/data/app/~~37wP-zifceloViDoIaZiLQ==/de.kggaming.application-MT0rnPML9HHvlPgijekxXw==/lib/arm64, /system/lib64]]
at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:207)
at java.lang.ClassLoader.loadClass(ClassLoader.java:379)
at java.lang.ClassLoader.loadClass(ClassLoader.java:312)
at com.onesignal.PushRegistratorFCM.getToken(PushRegistratorFCM.java:60)
at com.onesignal.PushRegistratorAbstractGoogle.attemptRegistration(PushRegistratorAbstractGoogle.java:97)
at com.onesignal.PushRegistratorAbstractGoogle.access0(PushRegistratorAbstractGoogle.java:37)
at com.onesignal.PushRegistratorAbstractGoogle.run(PushRegistratorAbstractGoogle.java:84)
at java.lang.Thread.run(Thread.java:923)
这是我的build.gradle(项目):
// Top-level build file where you can add configuration options common to all sub-projects/modules.
buildscript {
repositories {
google()
mavenCentral()
gradlePluginPortal()
}
dependencies {
classpath "com.android.tools.build:gradle:4.2.0"
classpath 'com.google.gms:google-services:4.3.8'
classpath 'gradle.plugin.com.onesignal:onesignal-gradle-plugin:[0.12.10, 0.99.99]'
// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
}
}
allprojects {
repositories {
google()
mavenCentral()
}
}
task clean(type: Delete) {
delete rootProject.buildDir
}
这是我的应用程序 build.gradle:
plugins {
id 'com.onesignal.androidsdk.onesignal-gradle-plugin'
id 'com.android.application'
id 'com.google.gms.google-services'
}
android {
compileSdkVersion 30
defaultConfig {
applicationId "de.kggaming.application"
minSdkVersion 26
targetSdkVersion 30
versionCode 1
versionName "1.0"
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
}
}
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
}
dependencies {
implementation 'androidx.appcompat:appcompat:1.3.0'
implementation 'com.google.android.material:material:1.3.0'
implementation 'androidx.constraintlayout:constraintlayout:2.0.4'
implementation 'com.google.firebase:firebase-messaging:22.0.0'
testImplementation 'junit:junit:4.+'
androidTestImplementation 'androidx.test.ext:junit:1.1.2'
androidTestImplementation 'androidx.test.espresso:espresso-core:3.3.0'
implementation platform('com.google.firebase:firebase-bom:28.0.1')
implementation 'com.google.firebase:firebase-analytics'
implementation 'com.onesignal:OneSignal:[4.0.0, 4.99.99]'
}
这里是应用class:
package de.kggaming.application;
import android.app.Application;
import com.onesignal.OneSignal;
public class ApplicationClass extends Application {
private static final String ONESIGNAL_APP_ID = "XXXXXXXXXXXXXXXXXXXXXXXX";
@Override
public void onCreate() {
super.onCreate();
OneSignal.setLogLevel(OneSignal.LOG_LEVEL.DEBUG, OneSignal.LOG_LEVEL.DEBUG);
// OneSignal Initialization
OneSignal.initWithContext(this);
OneSignal.setAppId(ONESIGNAL_APP_ID);
}
}
该应用程序没有任何功能。只是一个空 activity 和这个信号实现。
你能帮我解决这个问题吗?
谢谢!
此致,
Gismo
class com.google.firebase.iid.FirebaseInstanceId 已被弃用并从最新版本的 aar 中删除:
com.google.firebase.firebase-iid
参见link。
您在项目中拥有的 OneSignal 版本需要 aar 文件的 20.x.x 版本,而该版本仍然具有 class。但是,如果您包含该 aar 文件的 v20.x.x,您将开始在使用的 firebase-messaging:22.0.0 库中出现重复的 class 错误。
所以,我能提出的唯一解决方案是将您正在使用的 OneSignal SDK 更新到最新版本。
解析失败:Lcom/google/firebase/iid/FirebaseInstanceId
在尝试初始化依赖于 firebase SDK 的 hypertrack_plugin
时,我的 flutter 项目遇到了类似的问题。
经过两天的搜索后,在 android/app/build.gradle
中添加了此实现
希望此解决方案也能解决您的问题。
dependencies {
implementation "com.google.firebase:firebase-iid"
}
从这个 Link
中找到了解决方案
我有一个问题。 我无法使用 OneSignal。我不知道为什么。我用谷歌搜索了这个错误,但没有任何帮助。
目前我使用 Android Studio 版本:4.2 OneSignal最新版本:4.3.4 还有最新的 Firebase 版本。我创建了一个新的 Firebase 项目和 OneSignal 项目。
这是错误:
2021-05-25 13:06:37.370 3225-4181/de.kggaming.application E/OneSignal: Unknown error getting FCM Token
java.lang.NoClassDefFoundError: Failed resolution of: Lcom/google/firebase/iid/FirebaseInstanceId;
at com.onesignal.PushRegistratorFCM.getToken(PushRegistratorFCM.java:60)
at com.onesignal.PushRegistratorAbstractGoogle.attemptRegistration(PushRegistratorAbstractGoogle.java:97)
at com.onesignal.PushRegistratorAbstractGoogle.access0(PushRegistratorAbstractGoogle.java:37)
at com.onesignal.PushRegistratorAbstractGoogle.run(PushRegistratorAbstractGoogle.java:84)
at java.lang.Thread.run(Thread.java:923)
Caused by: java.lang.ClassNotFoundException: Didn't find class "com.google.firebase.iid.FirebaseInstanceId" on path: DexPathList[[dex file "/data/data/de.kggaming.application/code_cache/.overlay/base.apk/classes3.dex", zip file "/data/app/~~37wP-zifceloViDoIaZiLQ==/de.kggaming.application-MT0rnPML9HHvlPgijekxXw==/base.apk"],nativeLibraryDirectories=[/data/app/~~37wP-zifceloViDoIaZiLQ==/de.kggaming.application-MT0rnPML9HHvlPgijekxXw==/lib/arm64, /system/lib64]]
at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:207)
at java.lang.ClassLoader.loadClass(ClassLoader.java:379)
at java.lang.ClassLoader.loadClass(ClassLoader.java:312)
at com.onesignal.PushRegistratorFCM.getToken(PushRegistratorFCM.java:60)
at com.onesignal.PushRegistratorAbstractGoogle.attemptRegistration(PushRegistratorAbstractGoogle.java:97)
at com.onesignal.PushRegistratorAbstractGoogle.access0(PushRegistratorAbstractGoogle.java:37)
at com.onesignal.PushRegistratorAbstractGoogle.run(PushRegistratorAbstractGoogle.java:84)
at java.lang.Thread.run(Thread.java:923)
这是我的build.gradle(项目):
// Top-level build file where you can add configuration options common to all sub-projects/modules.
buildscript {
repositories {
google()
mavenCentral()
gradlePluginPortal()
}
dependencies {
classpath "com.android.tools.build:gradle:4.2.0"
classpath 'com.google.gms:google-services:4.3.8'
classpath 'gradle.plugin.com.onesignal:onesignal-gradle-plugin:[0.12.10, 0.99.99]'
// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
}
}
allprojects {
repositories {
google()
mavenCentral()
}
}
task clean(type: Delete) {
delete rootProject.buildDir
}
这是我的应用程序 build.gradle:
plugins {
id 'com.onesignal.androidsdk.onesignal-gradle-plugin'
id 'com.android.application'
id 'com.google.gms.google-services'
}
android {
compileSdkVersion 30
defaultConfig {
applicationId "de.kggaming.application"
minSdkVersion 26
targetSdkVersion 30
versionCode 1
versionName "1.0"
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
}
}
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
}
dependencies {
implementation 'androidx.appcompat:appcompat:1.3.0'
implementation 'com.google.android.material:material:1.3.0'
implementation 'androidx.constraintlayout:constraintlayout:2.0.4'
implementation 'com.google.firebase:firebase-messaging:22.0.0'
testImplementation 'junit:junit:4.+'
androidTestImplementation 'androidx.test.ext:junit:1.1.2'
androidTestImplementation 'androidx.test.espresso:espresso-core:3.3.0'
implementation platform('com.google.firebase:firebase-bom:28.0.1')
implementation 'com.google.firebase:firebase-analytics'
implementation 'com.onesignal:OneSignal:[4.0.0, 4.99.99]'
}
这里是应用class:
package de.kggaming.application;
import android.app.Application;
import com.onesignal.OneSignal;
public class ApplicationClass extends Application {
private static final String ONESIGNAL_APP_ID = "XXXXXXXXXXXXXXXXXXXXXXXX";
@Override
public void onCreate() {
super.onCreate();
OneSignal.setLogLevel(OneSignal.LOG_LEVEL.DEBUG, OneSignal.LOG_LEVEL.DEBUG);
// OneSignal Initialization
OneSignal.initWithContext(this);
OneSignal.setAppId(ONESIGNAL_APP_ID);
}
}
该应用程序没有任何功能。只是一个空 activity 和这个信号实现。
你能帮我解决这个问题吗?
谢谢!
此致,
Gismo
class com.google.firebase.iid.FirebaseInstanceId 已被弃用并从最新版本的 aar 中删除:
com.google.firebase.firebase-iid
参见link。
您在项目中拥有的 OneSignal 版本需要 aar 文件的 20.x.x 版本,而该版本仍然具有 class。但是,如果您包含该 aar 文件的 v20.x.x,您将开始在使用的 firebase-messaging:22.0.0 库中出现重复的 class 错误。
所以,我能提出的唯一解决方案是将您正在使用的 OneSignal SDK 更新到最新版本。
解析失败:Lcom/google/firebase/iid/FirebaseInstanceId
在尝试初始化依赖于 firebase SDK 的 hypertrack_plugin
时,我的 flutter 项目遇到了类似的问题。
经过两天的搜索后,在 android/app/build.gradle
希望此解决方案也能解决您的问题。
dependencies {
implementation "com.google.firebase:firebase-iid"
}
从这个 Link
中找到了解决方案