1.問題

Debian 7.5で “jar”を実行し、以下のエラーメッセージを表示します:

$ java -jar ripecrawler.jar
Exception in thread "main" java.lang.UnsupportedClassVersionError:
    com/mkyong/whois/job/RipeCrawlJob : Unsupported major.minor version 51.0

    at java.lang.ClassLoader.defineClass1(Native Method)
    at java.lang.ClassLoader.defineClass(ClassLoader.java:643)
    at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
    at java.net.URLClassLoader.defineClass(URLClassLoader.java:277)
    at java.net.URLClassLoader.access$000(URLClassLoader.java:73)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:212)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:205)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:323)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:294)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:268)

Debianが使っているJavaバージョンの簡単な確認

$ java -version
java version "1.6.0__31"
OpenJDK Runtime Environment (IcedTea6 1.13.3) (6b31-1.13.3-1~deb7u1)
OpenJDK 64-Bit Server VM (build 23.25-b01, mixed mode)

2.理由

これは、「jar」がJDK 1.7でコンパイルされているが、JDK 1.6環境で実行しようとしているためです。次のhttp://en.wikipedia.org/wiki/Java

class

file[Wikipedia Javaクラスリファレンス]を参照してください。

J2SE 8 = 52 (0x34 hex)
J2SE 7 = 51 (0x33 hex)
J2SE 6.0 = 50 (0x32 hex)
J2SE 5.0 = 49 (0x31 hex)
JDK 1.4 = 48 (0x30 hex)
JDK 1.3 = 47 (0x2F hex)
JDK 1.2 = 46 (0x2E hex)
JDK 1.1 = 45 (0x2D hex)


P.S major.minorバージョン51.0 = JDK 1.7/7

たとえば、JDK 1.6で “jar”をコンパイルし、JDK 1.5環境で実行しようとすると、エラーメッセージは次のように変わります。

Unsupported major.minor version 50.0

3.解決策

これを修正するには、JDK 7をダウンロードし、デフォルトのJDKを1.6から1.7に変更します


3.1

openjdk-7-jdkをダウンロードしてインストールしてください

$ sudo apt-get install openjdk-7-jdk openjdk-7-jre


3.2

デフォルトのJavaを1.7に変更します(Debianのようなシステムでのみ動作します)。

$ sudo update-alternatives --config java
There are 2 choices for the alternative java (providing/usr/bin/java).

  Selection    Path                                            Priority   Status
------------------------------------------------------------

**  0/usr/lib/jvm/java-6-openjdk-amd64/jre/bin/java 1061自動モード

1/usr/lib/jvm/java-6-openjdk-amd64/jre/bin/java 1061手動モード2/usr/lib/jvm/java-7-openjdk-amd64/jre/bin/java 1051手動モード

Enterキーを押して現在の選択肢[** ]を保持するか、選択番号を入力します:2
update-alternatives:/usr/lib/jvm/java-7-openjdk-amd64/jre/bin/javaを使用する
手動モードで/usr/bin/java(java)を提供する

$ java -version
Javaバージョン "1.7.0__55"
OpenJDKランタイム環境(IcedTea 2.4.7)(7u55-2.4.7-1〜deb7u1)
OpenJDK 64ビットサーバVM(ビルド24.51-b03、混合モード)

完了しました。