【Flutter】 Firebaseとの連携ができず奮闘しています。3<また先が見えなくなった。~JDK周り~>

Flutterで開発がしたいです。Flutter初心者だけど頑張っています。

FlutterのJDKJava 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.」というのが出ました。

qiita.com

このサイトにあるように、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を使うようにします。