UKey's Labo

Android toolchainの導入

概要

Android Studioを導入後、flutter doctor で状況を確認すると、以下のような表示が出る。

[!] Android toolchain - develop for Android devices (Android SDK version 30.0.3)
    ✗ Android license status unknown.
      Run `flutter doctor --android-licenses` to accept the SDK licenses.
      See https://flutter.dev/docs/get-started/install/macos#android-setup for more details.

そこで、出力されているログの通り、以下のコマンドを実行すると。。

flutter doctor --android-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:581)
        at java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(ClassLoaders.java:178)
        at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:522)
        ... 5 more

何か、Exceptionが発生する。。

解決

Android Studioから、Android SDK Command-line Toolsをインストールする。

Android Studioを開き、

Preference.. (⌘ + , でも可) > Appearance & Behavior > System Settings > Android SDK > SDK Tools(タブ)を開く。

Android SDK Command-line Tools にチェックを入れ、OKボタン押下。

インストールを進める。

Accept を選択し、 Nextボタン押下。

インストールが完了すれば、OK。

ここまできたら、再度以下を実行。

flutter doctor --android-licenses

ライセンスに同意(Accept? (y/N):yを入力)していけば、完了。

flutter doctorの結果でも、

[✓] Android toolchain - develop for Android devices (Android SDK version 30.0.3)

が出力される。

参考サイト