FCM - onTokenRefresh永远不会在多风味的Android应用程序上调用

时间:2017-04-07 04:11:34

标签: android firebase google-play-services firebase-cloud-messaging

我有一个多味的Android应用程序。两种flavor(com.mycompany.base)的包名称相同。在app level gradle文件中,这两种风格有自己的应用程序ID(com.mycompany.firstflavor和com.mycompany.secondflavor)。

过去,对于地图等谷歌播放服务,我使用了两个应用程序ID并获取了包含两种风格信息的google-services.json文件。我只需要将这个json文件复制到我的应用程序中,一切正常。

最近我创建了一个FCM项目以实现推送通知,并像以前一样使用他们的应用程序ID将每个风格添加为应用程序。起初,我只在应用程序的建议位置包含了一个json文件的coppy。当我在一种风格上运行应用程序时,它表示Firebase已成功初始化。但是,从未调用onTokenRefresh方法。我在互联网上搜索过,并且有一些相关的主题,但没有一个解决方案适用于我的情况。当我在另一种风格上运行应用程序时,应用程序一直崩溃并显示错误消息:java.lang.NoSuchMethodError:没有静态方法zzb(Ljava / lang / Object; Ljava / lang / Object;)Ljava / lang / Object;在课堂Lcom / google / android / gms / common / internal / zzab;或其超级类('com.google.android.gms.common.internal.zzab'的声明出现在/data/app/com.suran.dwmobile-2/base.apk:classes2.dex)。问题发生在真实设备和模拟器上。然后我按照我在线阅读的一些建议将json文件复制到两个位置。现在,相同的json文件出现在每个flavo下的两个位置,例如app / src / firstflavor和app / src / secondflavor。但这根本没有帮助,我仍然有同样的问题。这只是调试模式。

当我运行应用程序并将build variant设置为release时,我收到了两条消息:com.android.build.api.transform.TransformException:java.util.zip.ZipException:重复条目:com / google /android/gms/common/internal/zzv$zza$zza.class。我找到了类似问题的一些答案,但没有一个能解决我的问题。

以下是我的清单文件的一部分,可能对调试有用:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:amazon="http://schemas.amazon.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    package="com.mycompany.base"
    android:versionCode="1"
    android:versionName="1.0">

    <uses-sdk
        android:minSdkVersion="10"
        android:targetSdkVersion="21"
    />

    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission   android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.GET_TASKS" />
    <uses-permission android:name="archos.permission.FULLSCREEN.FULL" />
    <uses-permission android:name="android.permission.EXPAND_STATUS_BAR"/>
    <uses-permission android:name="android.permission.SEND_SMS" android:required="false" />
    <uses-permission android:name="android.permission.CAMERA" android:required="false"/>

    <uses-feature android:name="android.permission.ACCESS_NETWORK_STATE" android:required="false"/>
    <uses-feature android:name="android.permission.ACCESS_COARSE_LOCATION" android:required="false" />
    <uses-feature android:name="android.permission.ACCESS_FINE_LOCATION" android:required="false" />

    <uses-feature android:name="android.hardware.camera" android:required="false" />
    <uses-feature android:name="android.hardware.camera.front" android:required="false" />
    <uses-feature android:name="android.hardware.camera.autofocus" android:required="false" />
    <uses-feature android:name="android.hardware.telephony" android:required="false" />
    <uses-feature android:glEsVersion="0x00020000" android:required="false"/>

    <application
    android:name=".application.BaseApplication"
    android:allowBackup="true"
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name"
    android:largeHeap="true"
    android:theme="@style/CompanyTheme"
    >
        <service android:name=".FBInstanceService">
            <intent-filter>
                <action android:name="come.google.firebase.INSTANCE_ID_EVENT" />
            </intent-filter>
        </service>

        <service android:name=".FBMessagingService">
            <intent-filter>
                <action android:name="com.google.firebase.MESSAGING_EVENT" />
            </intent-filter>
        </service>
    </application>
</manifest>

这是我的应用级gradle文件:

apply plugin: 'com.android.application'

android {
    compileSdkVersion 23
    buildToolsVersion '25.0.0'
    useLibrary 'org.apache.http.legacy'

    defaultConfig {
        minSdkVersion 10
        targetSdkVersion 23
        multiDexEnabled true
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"

    }

    signingConfigs {
        firstflavorRelease {
            storeFile file("XXXXXX.jks");
            storePassword("XXXXXXX");
            keyAlias "XXXXXXX";
            keyPassword "XXXXXXX";
        }

        secondflavorRelease {
            storeFile file("XXXXXXX.jks");
            storePassword("XXXXXXXX");
            keyAlias "XXXXXXXXX";
            keyPassword "XXXXXXXX";
        }
    }

    buildTypes {
        release {
        minifyEnabled false
        proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.txt'
        }

    }

    productFlavors {
        firstflavor {
            applicationId = "com.mycompany.firstflavor"
            signingConfig signingConfigs.firstflavorRelease
            versionCode 1000
            versionName "1.9.2"
        }

        secondflavor {
            applicationId = "com.mycompany.secondflavor"
            signingConfig signingConfigs.secondflavorRelease
            versionCode 1000
            versionName "1.2.2"
        }
    }

    testOptions {
        unitTests.returnDefaultValues = true
    }
}

dependencies {
    compile project(':myappCore')
    compile files('libs/amazonmaps-1.0.2.jar')
    compile files('libs/zbar.jar')
    testCompile 'junit:junit:4.12'
    testCompile 'org.mockito:mockito-core:1.9.5'
    androidTestCompile 'com.linkedin.dexmaker:dexmaker-mockito:2.2.0'

    androidTestCompile 'com.android.support:support-annotations:23.4.0'
    androidTestCompile 'com.android.support.test:runner:0.5'
    androidTestCompile 'com.android.support.test:rules:0.5'
    androidTestCompile 'com.android.support.test.espresso:espresso-core:2.2.2'
    androidTestCompile "com.android.support.test.espresso:espresso-intents:2.2.1"
    testCompile 'org.powermock:powermock-api-mockito:1.6.1'
    testCompile 'org.powermock:powermock-module-junit4-rule-agent:1.6.1'
    testCompile 'org.powermock:powermock-module-junit4-rule:1.6.1'
    testCompile 'org.powermock:powermock-module-junit4:1.6.1'
    testCompile "org.robolectric:robolectric:3.2.2"


    compile 'com.android.support:appcompat-v7:23.4.0'
    compile 'com.nostra13.universalimageloader:universal-image-loader:1.9.5'
    compile 'com.google.code.gson:gson:2.2.4'
    compile 'com.google.android.gms:play-services-maps:9.0.0'
    compile 'com.google.android.gms:play-services-gcm:9.0.0'
    compile 'com.google.android.gms:play-services-auth:9.0.0'
    compile 'com.android.support:support-v4:23.4.0'
    compile 'com.android.support:mediarouter-v7:23.4.0'
    compile 'com.google.firebase:firebase-core:9.2.1'
    compile 'com.google.firebase:firebase-messaging:9.2.1'
    compile 'org.jsoup:jsoup:1.10.2'
}

apply plugin: 'com.google.gms.google-services'

这是我的项目级gradle文件:

buildscript {
    repositories {
        jcenter()
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:2.3.1'
       classpath 'com.google.gms:google-services:3.0.0'
    }
}

allprojects {
    repositories {
        jcenter()
    }
}

非常感谢任何帮助!

1 个答案:

答案 0 :(得分:0)

经过几天的努力,我终于找到了问题所在。在我的清单文件中,我错误地将服务操作的Android名称设置为:come.google.firebase.INSTANCE_ID_EVENT而不是com.google.firebase.INSTANCE_ID_EVENT。