任务':app:transformClassesWithMultidexlistForDebug'的执行失败。 (INotificationSideChannel $ Stub $ Proxy吗?)

时间:2019-06-20 00:27:57

标签: nativescript nativescript-vue

我的Nativescript-Vue项目无故停止工作,我不知道为什么。 gradle构建因此错误而崩溃:

D8: Program type already present: android.support.v4.app.INotificationSideChannel$Stub$Proxy

FAILURE: Build failed with an exception.

* What went wrong:
Execution failed for task ':app:transformClassesWithMultidexlistForDebug'.
> com.android.build.api.transform.TransformException: Error while generating the main dex list:
  Error while merging dex archives:
  Learn how to resolve the issue at https://developer.android.com/studio/build/dependencies#duplicate_classes.
  Program type already present: android.support.v4.app.INotificationSideChannel$Stub$Proxy

我对使用Java进行本机android开发一无所知,所以由于许多时间,我一直在努力解决此错误..

这是我的app.graddle

apply plugin: "com.android.application"
apply plugin: "com.google.gms.google-services"
dependencies {
    configurations.all {
        resolutionStrategy.eachDependency { DependencyResolveDetails details ->
            def requested = details.requested
            if (requested.group == 'com.android.support' && requested.name != 'multidex' ) {
                details.useVersion '27.1.1'
            }
        }
    }
}

dependencies {
  implementation 'org.slf4j:slf4j-nop:1.7.25'

}

android {
  defaultConfig {
    multiDexEnabled true
    generatedDensities = []
    applicationId = "org.nativescript.application"
    project.ext {
      googlePlayServicesVersion = "+"
    }
  }
  aaptOptions {
    additionalParameters "--no-version-vectors"
  }
}

和我的package.json在这种情况下是由一个nativescript-plugin引起的,这就是我的想法:

{
  "name": "app",
  "version": "1.21",
  "license": "MIT",
  "nativescript": {
    "id": "org.nativescript.application",
    "tns-ios": {
      "version": "5.3.1"
    },
    "tns-android": {
      "version": "5.3.1"
    }
  },
  "scripts": {
    "dev:android": "tns debug android --bundle",
    "dev:ios": "tns debug ios --bundle",
    "lint": "eslint --ext .js,.vue .",
    "run:android": "tns run android --bundle",
    "run:ios": "tns run ios --bundle",
    "clean": "tns platform clean ios; tns platform clean android"
  },
  "dependencies": {
    "axios": "^0.18.0",
    "dotenv-webpack": "^1.7.0",
    "nativescript": "^5.2.4",
    "nativescript-applozic-chat": "^1.2.4",
    "nativescript-appversion": "^1.4.1",
    "nativescript-barcodescanner": "^3.0.3",
    "nativescript-camera": "^4.2.0",
    "nativescript-cardview": "^3.1.1",
    "nativescript-checkbox": "^3.0.3",
    "nativescript-floatingactionbutton": "^5.0.0",
    "nativescript-geolocation": "^4.4.2",
    "nativescript-google-maps-sdk": "^2.7.0",
    "nativescript-google-places-autocomplete": "^1.0.3",
    "nativescript-iqkeyboardmanager": "^1.4.0",
    "nativescript-keyboard-toolbar": "^1.0.4",
    "nativescript-laravel-echo": "^1.0.1",
    "nativescript-lottie": "^3.0.2",
    "nativescript-modal-datetimepicker": "^1.1.12",
    "nativescript-oauth2": "^1.4.1",
    "nativescript-pager": "^9.3.14",
    "nativescript-phone": "^1.4.0",
    "nativescript-plugin-firebase": "^8.1.1",
    "nativescript-plugin-gplaces": "^2.4.6",
    "nativescript-vue": "^2.0.0",
    "nativescript-websockets": "^1.5.3",
    "nativescript-windowed-modal": "^5.0.6",
    "promise.prototype.finally": "^3.1.0",
    "pusher-nativescript": "^1.0.0",
    "tns-android": "^5.2.1",
    "tns-core-modules": "^5.2.2",
    "tns-ios": "^5.2.0",
    "ts-loader": "^5.3.3",
    "vue-i18n": "^8.9.0",
    "vuelidate": "^0.7.4",
    "vuex": "^3.0.1"
  },
  "devDependencies": {
    "@babel/core": "^7.0.0",
    "@babel/plugin-proposal-class-properties": "^7.4.4",
    "@babel/preset-env": "^7.0.0",
    "@vue/eslint-config-prettier": "^4.0.1",
    "babel-eslint": "^10.0.1",
    "babel-loader": "^8.0.2",
    "babel-traverse": "6.26.0",
    "babel-types": "6.26.0",
    "babylon": "6.18.0",
    "base-64": "^0.1.0",
    "clean-webpack-plugin": "^1.0.1",
    "copy-webpack-plugin": "^4.5.2",
    "css-loader": "^1.0.0",
    "date-fns": "^1.30.1",
    "eslint": "^5.12.1",
    "eslint-config-prettier": "^4.1.0",
    "eslint-plugin-prettier": "^3.0.1",
    "eslint-plugin-vue": "^5.1.0",
    "lazy": "1.0.11",
    "lodash": "^4.17.11",
    "nativescript-dev-typescript": "^0.9.0",
    "nativescript-dev-webpack": "^0.21.0-next-2019-02-15-084520-01",
    "nativescript-image-cache-it": "^4.1.2",
    "nativescript-vue-template-compiler": "^2.0.0",
    "node-sass": "^4.9.2",
    "prettier": "^1.16.1",
    "sass-loader": "^7.1.0",
    "terser-webpack-plugin": "^1.1.0",
    "tns-platform-declarations": "^5.2.2",
    "utf8": "^3.0.0",
    "vue-loader": "^15.2.6",
    "webpack": "^4.16.4",
    "webpack-bundle-analyzer": "~3.0.4",
    "webpack-cli": "^3.1.0"
  }
}

我尝试了很多事情:

  • rm -rf钩子/平台/node_modules/package-lock.json并重新编译整个项目
  • 删除C:/ Users / username /中的整个.gradle目录,然后重新编译
  • 卸载Java,并全局安装,重新安装和重新编译本机脚本cli(tns)
  • 按照本机脚本文档中的要求,卸载在C:/ Android中安装了Chocolatey的android-sdk,然后重新编译
  • tns平台清洁android
  • 重新克隆我的项目,然后尝试重新编译
  • 我非常绝望,我还为nativescript-vue和android创建了一个docker映像,以确保该错误与我的计算机配置/环境无关,并且该错误仍然在这里...

我试图编译一个用创建的空白项目:

vue init nativescript-vue/vue-cli-template

它正在工作。 另外,我的同事可以编译该项目,因此难以理解。我的项目与他们的项目相同,我确定该项目已重新克隆,并且他们没有未提交的文件...

1 个答案:

答案 0 :(得分:-1)

我发现错误是由以下软件包引起的:“ nativescript-google-maps-sdk”。也许是我没有卸载的唯一原因之一,以查看它是否是导致此错误的原因。...

无论如何,您可以在这里找到我如何解决此问题的方法: https://github.com/dapriett/nativescript-google-maps-sdk/issues/345#issuecomment-503321201