質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
Scala

ScalaはJava仮想マシンで動作を行うオブジェクト指向型プログラミング言語の1つです。静的型付けの関数型言語で、コンパイルエラーの検出に強みがあります。

Play Framework 2

Play Framework 2はPlayのメジャーバージョンです。現代の web アプリケーション開発に必要なコンポーネント及び API を統合した生産性の高い Java と Scala の web アプリケーションフレームワークです。

Q&A

解決済

1回答

2904閲覧

playframeworkでの実行時エラー

yochun02

総合スコア76

Scala

ScalaはJava仮想マシンで動作を行うオブジェクト指向型プログラミング言語の1つです。静的型付けの関数型言語で、コンパイルエラーの検出に強みがあります。

Play Framework 2

Play Framework 2はPlayのメジャーバージョンです。現代の web アプリケーション開発に必要なコンポーネント及び API を統合した生産性の高い Java と Scala の web アプリケーションフレームワークです。

0グッド

0クリップ

投稿2019/10/30 03:30

編集2019/10/30 03:31

scala-playframeworkでwebアプリを開発しているのですが、今まではビルドが通っていたのですが、急にjavaで以下のような実行時エラーが出て強制終了するようになりました。

エラー内容

plain

1Uncaught error from thread [application-akka.actor.default-dispatcher-10]: controllers/routes has been compiled by a more recent version of the Java Runtime (class file version 56.0), 2this version of the Java Runtime only recognizes class file versions up to 52.0, 3shutting down JVM since 'akka.jvm-exit-on-fatal-error' is enabled for ActorSystem[application] 4java.lang.UnsupportedClassVersionError: controllers/routes has been compiled by a more recent version of the Java Runtime (class file version 56.0), this version of the Java Runtime only recognizes class file versions up to 52.0 5 at java.lang.ClassLoader.defineClass1(Native Method) 6 ... 7 .. 8 .

試したこと

compiled by a more recent version of the Java Runtime (class file version 56.0)とあるので(過去に似た記事などを参考に)、javaとjavacのバージョンが違っているのかなと思いコンソール上で確認したのですが、

plain

1> javac -version 2java version "1.8.0_221" 3> java -version 4java version "1.8.0_221" 5Java(TM) SE Runtime Environment (build 1.8.0_221-b11) 6Java HotSpot(TM) 64-Bit Server VM (build 25.221-b11, mixed mode)

となっており、バージョンは同じなのにコンパイルされるときに別のバージョンを使っているみたいです。intelliJのコンパイラ設定で--release 8オプションを付けたりしてみましたがうまくいきませんでした。クラスのバージョンを見るに別にインストールした12の方(環境変数には設定していない)を使っているのかなと思ってみたり...。
どなたか原因がわかる方いましたら教えてください。

環境

Windows10
Java: Javaのインストールディレクトリに以下のファイル
jdk1.8.0_221
jdk1.2.0.1
jre1.8.0_221

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

rysh

2019/10/30 04:22

sbtコンソールで下記のコマンドを使うとバージョンが確認できるようなのでsbt上で何が使われているか確認した方がいいかも。 > eval System.getProperty("java.version") > eval System.getProperty("java.home") あと、Intellijを使わずにConsoleからsbtで実行するとどうなりますか?
yochun02

2019/10/30 04:37

$ eval System.getProperty("java.version") [info] ans: String = 1.8.0_221 $ eval System.getProperty("java.home") [info] ans: String = C:\Program Files\Java\jdk1.8.0_221\jre でした(あってるような...) 実行はWindowsのPowerShellから実行しています
rysh

2019/10/30 05:04

ダメ元ですが、cleanとcleanFilesはためしました?
yochun02

2019/10/30 05:29 編集

いろいろ弄っておりましたところ自己解決しました...!相談に乗っていただきありがとうございましたm(_ _)m
guest

回答1

0

自己解決

個人的な環境すぎて自己解決法を書いてもあまり意味がないかもしれませんが...一応...
どうやらgitで管理していたサブモジュール側の方が古いままだったのが原因でした。(そちら側の設定が更新されてなかった?)
リポジトリを分離してて、親ディレクトリが子ディレクトリのリポジトリを参照するようにしている

解決した方法としては
git submodule updateをかましただけです。

投稿2019/10/30 05:25

yochun02

総合スコア76

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問