非IT企業に勤める中年サラリーマンのIT日記

非IT企業でしかもITとは全く関係ない部署にいる中年エンジニア。唯一の趣味がプログラミングという”自称”プログラマー。

Ubuntu20.04にFlutterをインストールしようとしたらAndroidライセンスでハマって解決したのでメモ

   

Ubuntu20.04にFlutterをインストールしようとしたら、Androidライセンス取得でエラー(Android license status unknown)が出てハマったので、対処法を書き留めておきます。

 

Android license

flutterのインストール後にflutter doctorを起動して開発環境の取得状況を確認します。最初はだいたい↓こんな感じに出るんじゃないでしょうか。

$ flutter doctor
Doctor summary (to see all details, run flutter doctor -v):
[✓] Flutter (Channel stable, 1.22.3, on Linux, locale ja_JP.UTF-8)
[!] Android toolchain - develop for Android devices (Android SDK version 30.0.2)
✗ Android license status unknown.
Run `flutter doctor --android-licenses` to accept the SDK licenses.
See https://flutter.dev/docs/get-started/install/linux#android-setup for more details.
[!] Android Studio (not installed)
[!] VS Code (version 1.50.1)
✗ Flutter extension not installed; install from
https://marketplace.visualstudio.com/items?itemName=Dart-Code.flutter
[!] Connected device
! Device OUKIC15PRO067436 is not authorized.
You might need to check your device for an authorization dialog.

! Doctor found issues in 4 categories.
 

 

 

最初のAndroid license status unknown.を解消するために、指示のある通りに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
 

 

…という感じで、Java関連でエラーが出てしまいました。

 

先に言っておくと、Javaを触ったことがある人はピンと来ると思いますが、Javaの実行ファイルが現行のJavaバージョンと合わない時に起きるエラーです(mainクラスがない時も同じエラーが出るんだけどね)。

調べてみるとやはりAndroid StudioはJava 9以降に対応しておらず、Java8じゃなきゃダメだそうです。この時点で僕のマシンのJavaバージョンは11だったので原因は判明しました。

 

Javaのオプション指定で解決…しなかった

ググってみるとJavaのオプション指定で解決するとのことなので、紹介されていた通りのコマンドを実行してみました。

$ export JAVA_OPTS='-XX:+IgnoreUnrecognizedVMOptions --add-modules java.se.ee'
 

 

…ですが、解決できず。同じエラーが出るだけでした。

 

結局Javaのバージョンを8にするしかないんだよね

バージョンダウンはちょっと悔しいですが、いろいろ試した挙げ句これしか解決策なさそうと断念。

まずは、インストールしていたJava11をアンインストールする必要あります。UbuntuですべてのJavaパッケージを削除するコマンドは以前以下の記事で書きました。

 

コマンドはこれです。これでJavaの全パッケージを削除できます。

$ dpkg-query -W -f='${binary:Package}\n' | grep -E -e '^(ia32-)?(sun|oracle)-java' -e '^openjdk-' -e '^icedtea' -e '^(default|gcj)-j(re|dk)' -e '^gcj-(.*)-j(re|dk)' -e '^java-common' | xargs sudo apt-get -y remove
$ sudo apt-get -y autoremove
 

 

で、Java8をインストール。

$ sudo apt install openjdk-8-jdk-headless
 

 

もう一度flutter doctorを実行してみるとご覧の通り「Android toolchain」がOKになりました。

$ flutter doctor
Doctor summary (to see all details, run flutter doctor -v):
[✓] Flutter (Channel stable, 1.22.3, on Linux, locale ja_JP.UTF-8)
[✓] Android toolchain - develop for Android devices (Android SDK version 30.0.2)
[!] Android Studio (not installed)
[!] VS Code (version 1.50.1)
✗ Flutter extension not installed; install from
https://marketplace.visualstudio.com/items?itemName=Dart-Code.flutter
[!] Connected device
! Device OUKIC15PRO067436 is not authorized.
You might need to check your device for an authorization dialog.
 

 

 

スポンサーリンク

 - Androidプログラミング, Flutter/Dart, Linux