环境
系统:Windows
Flutter:3.19.6
connectivity_plus:6.0.3
问题描述
Flutter升级到3.19.6,connectivity_plus库升级到6.0.3后,运行项目时报错Execution failed for task ‘:connectivity_plus:compileDebugJavaWithJavac’,如下图:
可以得知在运行时gradle在编译connectivity_plus库的过程中遇到了一个与编译Java相关的错误。
解决方案
-
首先猜想可能是该库的版本太高,尝试降版本到5.0.2后,其他库也会报同样的错误,所以降低版本不是一个好的解决方法,没有从根源解决问题。
-
其次猜测可能是当前flutter版本与jdk版本、gradle版本不匹配,既然报错和java有关,多半是jdk的版本问题,于是接下来根据这两篇文章查看了我自己的android studio版本和jdk版本:
https://juejin.cn/post/7221808657531961401
https://juejin.cn/s/android%20studio%20%E7%89%88%E6%9C%AC%E5%8D%87%E7%BA%A7第一步,由于发现我的android studio确实比较老了,是22年的版本,于是进行升级,升级到2023.3.1.18,注意安装时保存旧的配置以免影响到项目。
第二步,配置环境变量:JAVA_HOME以及path:
配置好以后,重新打开flutter项目,运行flutter clean,重新flutter pub get,然后运行项目,可以正常运行。
总结
类似库的报错一般都是和 jdk 相关的,在定位问题的时候可以顺着这个方向查,或者询问小G。我升级android studio之后,jdk版本其实还是之前那个旧的,所以实际的原因可能还是我没有配置JAVA_HOME,或者没有在android studio -> File -> Project Structure中选择SDK等,导致gradle执行的时候找不到可用的jdk。
一些经验:
-
[可以尝试不使用fvm] 升级过好几次flutter,每次升级都不是很顺利,越来越觉得其实fvm管理flutter版本不是特别好用,有时候切换好版本之后,fvm list显示的是正确版本,但是报错又会出现current dart sdk xxx(实际切换的flutter版本对应的dart已经是3.3.4了):
-
[记得查看flutter doctor] 跑flutter doctor可以看到本地安装的各个工具的情况,有时候确实可以发现问题,或者起码提供思路。
-
[force updage 强制更新库] 有时候跟某个package版本相关的报错,实在找不到好的解决方法,可以flutter clean后运行flutter update-packages --force-upgrade,然后再pub get,强制根据pubspec.yaml中配置的版本更新库。