📖

Flutterのセットアップ中、flutter doctor --android-licensesでエラーが発生する

2 min read 2

環境情報

  • macOS Big Sur 11.3.1

経緯と事象

Flutterが正しくセットアップされているか確認するためにdoctorコマンドを実行したら、Android licenseの状態が不明と言われました。

$ 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 を実行すると以下のようなエラーが発生しました。

$ 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

解決策

1.Android Studioを起動して、Welcome to Android Studioのダイアログから、「Configure」→「SDK Manager」を起動します。

2.Appearance&Behavior → System Settings → Android SDK で SDK Toolsを選択します。

3.「Android SDK Build-Tools xx」と「Android SDK Command-line Tools(latest)」にチェックをいれ、「Apply」を押してインストールします。

4.コンソールからflutter doctor --android-licensesを実行するとライセンス承諾画面が表示されるので、承認します。

5.flutter doctorを実行して解決できていることを確認します。

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

公式ドキュメントによると本来であればAndroid Studioをインストールするときに、Build ToolsやCommand-line Toolsもインストールされるようです。
今回、Macのセキュリティーとプライバシーに引っかかってインストールできていなかったようです。

備考

途中、Homebrewで java や openjdk@8 をインストールしたんだけど、現象は解決しませんでした。
おそらくTool系がインストールされていなかったことが原因かと思います。