【Flutter】 Firebaseとの連携ができず奮闘しています。3<また先が見えなくなった。~JDK周り~>
Flutterで開発がしたいです。Flutter初心者だけど頑張っています。
FlutterのJDK(Java Development Kit)ってどのバージョンを使えばいいのでしょう。
今日はここで詰まったのでメモを残します。
どう詰まったか
現在どうしてもJDK14を使いたい事情が出てきて(そもそも動画コースのバグ改修をしています)。JDK8を使っていたのを、JDK14をインストールして、環境変数にJDK14のパスを設定しました。
flutter doctor -v にて、
X Android license status unknown. Try re-installing or updating your Android SDK Manager. See https://developer.android.com/studio/#downloads or visit https://flutter.dev/setup/#android-setup for detailed instructions.
「Android license status unknown.」というのが出ました。
このサイトにあるように、Androidのライセンス確認ができていない様子だということで、普通は「flutter doctor --android-licenses」で直るらしいのですが、直らない場合があるとのこと。そして私の場合はこの直らない方でした。
sdkmanager --licenses をすると
Exception in thread "main" java.lang.NoClassDefFoundError: javax/xml/bind/annotation/XmlSchema at com.android.repository.api.SchemaModule$SchemaModuleVersion.<init>(SchemaModule.java:156) at com.android.repository.api.SchemaModule.<init>(SchemaModule.java:75) at com.android.sdklib.repository.AndroidSdkHandler.<clinit>(AndroidSdkHandler.java:81) at com.android.sdklib.tool.sdkmanager.SdkManagerCli.main(SdkManagerCli.java:73) at com.android.sdklib.tool.sdkmanager.SdkManagerCli.main(SdkManagerCli.java:48) Caused by: java.lang.ClassNotFoundException: javax.xml.bind.annotation.XmlSchema at java.base/jdk.internal.loader.BuiltinClassLoader.loadClass(BuiltinClassLoader.java:602) at java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(ClassLoaders.java:178) at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:522) ... 5 more
「java.lang.NoClassDefFoundError」というようなエラーが。これも先ほどのサイトに答えが書いてあり、現在のSDKのバージョンはJAVA9以降に対応しておらず、JAVA8で動かす必要があるとのことらしいです。
一応、上記サイトを進んで、下記のようなコマンドを売ってみました。
set JAVA_OPTS=-XX:+IgnoreUnrecognizedVMOptions --add-modules java.se.ee'
そして、flutter doctor --android-licensesをすると、
Error occurred during initialization of boot layer java.lang.module.FindException: Module java.se.ee' not found
「java.se.eeはないよ」ということで、JDK14にはこれはないのだなということがわかりました。
というわけで、JDK8を使うようにします。