[Flutter]Android license status unknown.でAndroid StudioのJavaを使うように設定した話

Flutterの初期設定でエラーが発生して、対応したときのメモ。
ネットで拾えたのと少し違う対応をしています。

概要

  • 「Android license status unknown.」のエラー
  • 原因は、環境変数JAVA_HOMEにJava 9以降のパスが設定されていたこと。
    ※Flutterは、Java 8を使う必要がある。
  • Androud Studioで使っているJavaを指定した。
    • 大抵、Java8 のJDKを新規にインストールしてパスを設定する方法を書いているけど、こっちのほうが良いと思うんだけど、ダメな理由あるのかな。
    • Javaってライセンスがうるさくなり、新たに入手するのが面倒くさいし。
    • Androud StudioのJavaのデフォルトパス「C:\Program Files\Android\Android Studio\jre」
      ※Android Studioのmenu、File – Project Structure- SDKs – JDK home path

エラー詳細

  • flutter doctorでエラー
    >flutter doctor
    Doctor summary (to see all details, run flutter doctor -v):
    [√] Flutter (Channel stable, v1.9.1+hotfix.6, on Microsoft Windows [Version 10.0.17763.134], locale ja-JP)
    [!] Android toolchain - develop for Android devices (Android SDK version 28.0.3)
    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 Studio (version 3.5)
    [√] Proxy Configuration
    [!] Connected device
    ! No devices available
        
    ! Doctor found issues in 2 categories.

Android toolchainのところでエラー。
※See ~~~のリンクに詳細載ってなくない?

  • ライセンスの更新コマンド

    >flutter doctor --android-licenses
    A newer version of the Android SDK is required. To update, run:
    C:\Users\username\AppData\Local\Android\sdk\tools\bin\sdkmanager --update
  • updateコマンド

    >C:\users\username\AppData\Local\Android\Sdk\tools\bin\sdkmanager.bat --update
    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:582)
        at java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(ClassLoaders.java:190)
        at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:499)
        ... 5 more

ここからでは、Java8でないことが原因であることは不明でした。
ネットで検索してやっと出てきました。

参考:

対策

Windowsの場合、環境変数のJAVA_HOMEにAndroud StudioのJavaパスを設定
temp

コメント

タイトルとURLをコピーしました