How to fix java.lang.UnsupportedClassVersionError: Unsupported major.minor version
I am trying to use Notepad++ as my all-in-one tool edit, run, compile, etc.
I have JRE installed, and I have setup my path variable to the .../bin directory.
When I run my "Hello world" in Notepad++, I get this message:
java.lang.UnsupportedClassVersionError: test_hello_world :
Unsupported major.minor version 51.0
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClassCond(Unknown Source)
.........................................
I think the problem here is about versions; some version of Java may be old or too new.
- How do I fix it?
- Should I install the JDK, and setup my path variable to the JDK instead of JRE?
- What is the difference between the
PATH
variable in JRE or JDK?
java jvm incompatibility unsupported-class-version
|
show 4 more comments
I am trying to use Notepad++ as my all-in-one tool edit, run, compile, etc.
I have JRE installed, and I have setup my path variable to the .../bin directory.
When I run my "Hello world" in Notepad++, I get this message:
java.lang.UnsupportedClassVersionError: test_hello_world :
Unsupported major.minor version 51.0
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClassCond(Unknown Source)
.........................................
I think the problem here is about versions; some version of Java may be old or too new.
- How do I fix it?
- Should I install the JDK, and setup my path variable to the JDK instead of JRE?
- What is the difference between the
PATH
variable in JRE or JDK?
java jvm incompatibility unsupported-class-version
did you install jdk as well ? jre is Java RunTime environment , To create java apps , you need jdk as well
– CyprUS
Apr 30 '12 at 11:30
yes i did, and now my path variable points to where jdk is. yet i still have this "unsupported minor version 51.0" error do you think i should install older version of jdk? i m using jdk 1.7.0
– ERJAN
May 1 '12 at 8:30
20
This happened to me on Mac OS X when I was having problems due to the weird Apple java 6 and Oracle java 7 situation on OSX these days. short version: Compile with JDK7, Run with JDK6, get this.
– Warren P
Oct 7 '13 at 4:00
6
In java ClassName should Be Start with Capital letter ;)
– Ashish Panery
Feb 3 '14 at 16:47
5
For El Captain, this answer fixed it for me: stackoverflow.com/a/34201991/1615594
– tsuz
Jan 24 '16 at 11:35
|
show 4 more comments
I am trying to use Notepad++ as my all-in-one tool edit, run, compile, etc.
I have JRE installed, and I have setup my path variable to the .../bin directory.
When I run my "Hello world" in Notepad++, I get this message:
java.lang.UnsupportedClassVersionError: test_hello_world :
Unsupported major.minor version 51.0
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClassCond(Unknown Source)
.........................................
I think the problem here is about versions; some version of Java may be old or too new.
- How do I fix it?
- Should I install the JDK, and setup my path variable to the JDK instead of JRE?
- What is the difference between the
PATH
variable in JRE or JDK?
java jvm incompatibility unsupported-class-version
I am trying to use Notepad++ as my all-in-one tool edit, run, compile, etc.
I have JRE installed, and I have setup my path variable to the .../bin directory.
When I run my "Hello world" in Notepad++, I get this message:
java.lang.UnsupportedClassVersionError: test_hello_world :
Unsupported major.minor version 51.0
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClassCond(Unknown Source)
.........................................
I think the problem here is about versions; some version of Java may be old or too new.
- How do I fix it?
- Should I install the JDK, and setup my path variable to the JDK instead of JRE?
- What is the difference between the
PATH
variable in JRE or JDK?
java jvm incompatibility unsupported-class-version
java jvm incompatibility unsupported-class-version
edited Mar 22 '17 at 16:20
Taryn♦
191k47291354
191k47291354
asked Apr 30 '12 at 11:28
ERJANERJAN
9,370123468
9,370123468
did you install jdk as well ? jre is Java RunTime environment , To create java apps , you need jdk as well
– CyprUS
Apr 30 '12 at 11:30
yes i did, and now my path variable points to where jdk is. yet i still have this "unsupported minor version 51.0" error do you think i should install older version of jdk? i m using jdk 1.7.0
– ERJAN
May 1 '12 at 8:30
20
This happened to me on Mac OS X when I was having problems due to the weird Apple java 6 and Oracle java 7 situation on OSX these days. short version: Compile with JDK7, Run with JDK6, get this.
– Warren P
Oct 7 '13 at 4:00
6
In java ClassName should Be Start with Capital letter ;)
– Ashish Panery
Feb 3 '14 at 16:47
5
For El Captain, this answer fixed it for me: stackoverflow.com/a/34201991/1615594
– tsuz
Jan 24 '16 at 11:35
|
show 4 more comments
did you install jdk as well ? jre is Java RunTime environment , To create java apps , you need jdk as well
– CyprUS
Apr 30 '12 at 11:30
yes i did, and now my path variable points to where jdk is. yet i still have this "unsupported minor version 51.0" error do you think i should install older version of jdk? i m using jdk 1.7.0
– ERJAN
May 1 '12 at 8:30
20
This happened to me on Mac OS X when I was having problems due to the weird Apple java 6 and Oracle java 7 situation on OSX these days. short version: Compile with JDK7, Run with JDK6, get this.
– Warren P
Oct 7 '13 at 4:00
6
In java ClassName should Be Start with Capital letter ;)
– Ashish Panery
Feb 3 '14 at 16:47
5
For El Captain, this answer fixed it for me: stackoverflow.com/a/34201991/1615594
– tsuz
Jan 24 '16 at 11:35
did you install jdk as well ? jre is Java RunTime environment , To create java apps , you need jdk as well
– CyprUS
Apr 30 '12 at 11:30
did you install jdk as well ? jre is Java RunTime environment , To create java apps , you need jdk as well
– CyprUS
Apr 30 '12 at 11:30
yes i did, and now my path variable points to where jdk is. yet i still have this "unsupported minor version 51.0" error do you think i should install older version of jdk? i m using jdk 1.7.0
– ERJAN
May 1 '12 at 8:30
yes i did, and now my path variable points to where jdk is. yet i still have this "unsupported minor version 51.0" error do you think i should install older version of jdk? i m using jdk 1.7.0
– ERJAN
May 1 '12 at 8:30
20
20
This happened to me on Mac OS X when I was having problems due to the weird Apple java 6 and Oracle java 7 situation on OSX these days. short version: Compile with JDK7, Run with JDK6, get this.
– Warren P
Oct 7 '13 at 4:00
This happened to me on Mac OS X when I was having problems due to the weird Apple java 6 and Oracle java 7 situation on OSX these days. short version: Compile with JDK7, Run with JDK6, get this.
– Warren P
Oct 7 '13 at 4:00
6
6
In java ClassName should Be Start with Capital letter ;)
– Ashish Panery
Feb 3 '14 at 16:47
In java ClassName should Be Start with Capital letter ;)
– Ashish Panery
Feb 3 '14 at 16:47
5
5
For El Captain, this answer fixed it for me: stackoverflow.com/a/34201991/1615594
– tsuz
Jan 24 '16 at 11:35
For El Captain, this answer fixed it for me: stackoverflow.com/a/34201991/1615594
– tsuz
Jan 24 '16 at 11:35
|
show 4 more comments
46 Answers
46
active
oldest
votes
1 2
next
The version number shown describes the version of the JRE the class file is compatible with.
The reported major numbers are:
Java SE 13 = 57,
Java SE 12 = 56,
Java SE 11 = 55,
Java SE 10 = 54,
Java SE 9 = 53,
Java SE 8 = 52,
Java SE 7 = 51,
Java SE 6.0 = 50,
Java SE 5.0 = 49,
JDK 1.4 = 48,
JDK 1.3 = 47,
JDK 1.2 = 46,
JDK 1.1 = 45
(Source: Wikipedia)
To fix the actual problem you should try to either run the Java code with a newer version of Java JRE or specify the target parameter to the Java compiler to instruct the compiler to create code compatible with earlier Java versions.
For example, in order to generate class files compatible with Java 1.4, use the following command line:
javac -target 1.4 HelloWorld.java
With newer versions of the Java compiler you are likely to get a warning about the bootstrap class path not being set. More information about this error is available in blog post New javac warning for setting an older source without bootclasspath.
157
"The version number shown describe which version if Java was used to compile the code." No it does not. It shows the version of the JRE that the class file is compatible with. Using cross-compilation options you can use a 1.7 JDK to compile code with a class version of 1.1 (through 1.7).
– Andrew Thompson
Jan 10 '13 at 5:31
80
This answer does not explain how to fix it as the question asked?
– Jonathan Leung
Mar 5 '13 at 12:58
7
This is a nice solution for compiling to a previous version from Eclipse directly: stackoverflow.com/a/16345710/2091700
– Alphaaa
May 23 '13 at 14:03
19
IN eclipse project=>Proerties=>java compiler; set "the compiler compliance level" to the version according to your jre or jdk. As for me, it's 1.6 for jre 1.6
– Sam
Sep 25 '13 at 14:58
5
This may occur when compiler source is set in non-compliance with currently compiling JRE/JDK. For example i found the below values from eclipse .settings folder, org.eclipse.jdt.core.compiler.compliance=1.7, org.eclipse.jdt.core.compiler.source=1.7, org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.7. And my compiler was 1.6.0_32. The problem was resolved after changing the values to 1.6. The issue originated after i copied the project from a different workspace where i was using JDK 1.7 :(
– Gana
Dec 22 '14 at 6:22
|
show 4 more comments
java.lang.UnsupportedClassVersionError
happens because of a higher JDK during compile time and lower JDK during runtime.
10
+1: changing this symbolic link (/etc/alternatives/java -> /usr/lib/jvm/java-6-openjdk-amd64/jre/bin/java
) to the version used for compilation with javac solved it
– ezdazuzena
Aug 6 '13 at 9:30
1
How can i make above change?
– Ankur Raiyani
Aug 14 '13 at 12:57
7
Project -> Properties -> Java Compiler Enable project specific settings. Then select Compiler Compliance Level to 1.7, 1.6 or 1.5, build and test your app.
– Vivek Kumar Ray
Aug 16 '13 at 9:55
More details please see the link vivekraicdac.blogspot.in
– Vivek Kumar Ray
Aug 16 '13 at 9:56
8
@ezdazuzena usesudo update-alternatives --config java
to do so.
– Thorbjørn Ravn Andersen
Jan 29 '14 at 10:06
|
show 4 more comments
In Eclipse, I just went to menu command Window -> Preferences -> Java -> Compiler and then set "Compiler compliance level" to 1.6.
3
In eclipse, sometime project facets also need to be changed to appropriate java version.
– Bilal Mirza
Jul 4 '13 at 7:59
6
Thanks. It's worth noting that setting Eclipse's default execution environment (the JRE that goes on the build path) is a separate setting. I had set the JRE but not the compiler compliance level; this fixed it.
– wchargin
Jan 26 '14 at 1:52
And how did you draw the conclusion from the error message that this was the right place to set the option?
– Alexander
Oct 24 '15 at 13:37
Maybe this: stackoverflow.com/questions/7073485/… can help if you are using ant and eclipse.
– OuuGiii
Aug 2 '17 at 7:46
add a comment |
Don't worry, I got it solved.
It is actually simple - you need to install BOTH JRE / JDK with the same version.
JRE 6 -> JDK 6
JRE 7 -> JDK 7
And so on.
25
java 7 can handle 6 without any problems too.
– damienix
Oct 31 '13 at 10:23
add a comment |
This error means you're trying to load a Java "class" file that was compiled with a newer version of Java than you have installed.
For example, your .class
file could have been compiled for JDK 7, and you're trying to run it with JDK 6.
So the solution is to either:
- Upgrade your Java runtime or
Recompile the class if you have the source, using your local Java compiler (if you have one).
javac FileName.java
For developers, this can happen if another developer checks in a .class file, and they've got a newer version of java than you have!
4
Except inside jars.
– Chris
Feb 12 '15 at 18:31
add a comment |
You are trying to run your program with a Java version that does not support the version in which the code was compiled. So basically you must have compiled your code with a higher version and trying to run it using a lower version.
As you are getting
Unsupported major.minor version 51.0
and version 51.0 corresponds to J2SE 7 you have most probably compiled your code in Java 7 and trying to run it using a lower version. Check what java -version
displays. It should be the Java 7 version. If not make appropriate changes in the PATH/JAVA_HOME. Or you can compile with the same version you are trying to run the code. If the configurations are confusing you can always give absolute path /home/user/jdk1.7.0_11/bin/javac
and /home/user/jdk1.7.0_11/bin/java
.
add a comment |
I had a similar situation on Mac, and the following process worked for me:
In the terminal, type
vi ~/.profile
Then add this line in the file, and save
export JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk<version>.jdk/Contents/Home
where version is the one on your computer, such as 1.7.0_25
.
Exit the editor, then type the following command make it become effective
source ~/.profile
Then type java -version to check the result
java -version
What is .profile
file?
.profile file is a hidden file. It is an optional file which tells the system which commands to run when the user whose profile file it is logs in. For example, if my username is bruno and there is a .profile file in /Users/bruno/, all of its contents will be executed during the log-in procedure.
Source: http://computers.tutsplus.com/tutorials/speed-up-your-terminal-workflow-with-command-aliases-and-profile--mac-30515
add a comment |
In Eclipse's menu Window -> Preferences -> Java -> Compiler check also "Configure Project Specific Settings".
If you stil have the error with same Java version: try to delete build folder of your project manually. Then restart Eclipse.
add a comment |
You can have some JAR library compiled in Java 7, and you have only Java 6 as Java Runtime. It could happen with some new libraries.
add a comment |
The most common issue is misconfiguration of your JAVA_HOME
variable which should point to the right Java Development Kit library, if you've multiple installed.
To find where SDK Java folder is located, run the following commands:
jrunscript -e 'java.lang.System.out.println(java.lang.System.getProperty("java.home"));'
Debian/Ubuntu
To check which java (openjdk) you've installed, check via:
dpkg -l "openjdk*" | grep ^i
or:
update-java-alternatives -l
To change it, use:
update-alternatives --config java
Prefix with sudo
if required.
to select the alternative java version.
Or check which are available for install:
apt-cache search ^openjdk
Prefix with sudo
if required.
Then you can install, for example:
apt-get install openjdk-7-jre
Prefix with sudo
if required.
Fedora, Oracle Linux, Red Hat
Install/upgrade appropriate package via:
yum install java-1.7.0-openjdk java-1.7.0-openjdk-devel
The
java-1.7.0-openjdk
package contains just the Java Runtime Environment. If you want to develop Java programs then install thejava-1.7.0-openjdk-devel
package.
BSD
There is an OpenJDK 7 package in the FreeBSD Ports collection called openjdk7 which probably needs to be reconfigured.
See: OpenJDK wiki page.
Windows
Just install appropriate Java SE Development Kit library from the Oracle site or install
Jenkins
If you're experiencing this issue with Jenkins, see:
- JENKINS-30561 - Unable to launch agent using SSH
However selecting the right version of Java (newer) with update-alternatives
should work.
This answer worked for me when trying to use spark2-shell on a host after adding the spark service to a cluster with cloudera.
– Alter
Nov 24 '17 at 23:16
add a comment |
I have faced the same problem when I was working with an Ant script to build my application.
I use Eclipse for my application development, and I changed the compiler version in build properties of the project. But that didn't work for me. Then I found out that I can provide the compiler version in the Ant script.
I modified the Ant script at the section where it compile Java files.
<target name="build-java" depends="prepare-build">
<echo message="Compiling java files"/>
<javac ....
target="1.5"...
</javac>
</target>
This worked for me to resolve the unsupported major minor issue.
add a comment |
When I installed JDK 1.7, the problem got solved.
add a comment |
I got the same problem with a project written in 1.7 and tried to execute in 1.6.
My solution in Eclipse:
Right click on your Project Properties -> Java Build Path -> Libraries
Select your JRE System Library and click Edit on the right, and choose the target JRE.
Now go to Java Compiler on the left, and change the Compiler compliance level to your target.
That worked for me.
add a comment |
As answered elsewhere by several people, the Java program is being run on an older version of Java than the one it was compiled it for. It needs to be "crosscompiled" for backward compatibility. To put it another way, there is a mismatch between source and target Java versions.
Changing options in Eclipse menus don't answer the original poster, who said he/she is not using Eclipse. On OpenJDK javac version 1.7, you can crosscompile for 1.6 if you use parameters -source
and -target
, plus provide the rt.jar -file of the target version (that is, the older one) at compile time. If you actually install the 1.6 JRE, you can point to its installation (for example, /usr/lib/jvm/java-6-openjdk-i386/jre/lib/rt.jar on Ubuntu, /usr/jdk/jdk1.6.0_60/jre/lib/rt.jar on SunOS apparently. Sorry, I don't know where it is on a Windows system). Like so:
javac -source 1.6 -target 1.6 -bootclasspath /usr/lib/jvm/java-6-openjdk-i386/jre/lib/rt.jar HelloWorld.java
It looks like you can just download rt.jar from the Internet, and point to it. This is not too elegant though:
javac -source 1.6 -target 1.6 -bootclasspath ./rt.jar HelloWorld.java
add a comment |
Based on this...
J2SE 8 = 52
J2SE 7 = 51
J2SE 6.0 = 50
J2SE 5.0 = 49
JDK 1.4 = 48
JDK 1.3 = 47
JDK 1.2 = 46
JDK 1.1 = 45
In Eclipse, right click on project in package explorer:
Build Path -> Configure Build Path
Under:
Java Build Path -> Libraries -> Add Library -> JRE System Library -> Installed JREs -> Search.
Add the required JRE by selecting the library in the list available after the search is complete.
add a comment |
If you use Maven, set your Java compile level. Open a command line and write
java -version
for your compile level:
If you use IntelliJ IDEA, select project → File → Settings → Build Execution Deployment → Compiler → Java Compiler. Then change byte code as 1.7 like this image:
I needed to do a maven clean install as well after changing the pom.
– Joe Borysko
Sep 22 '16 at 19:15
add a comment |
If you're facing this issue while using Maven, you can cross compile your code using the plug-in Maven Compiler.
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.1</version>
<configuration>
<source>1.6</source>
<target>1.6</target>
</configuration>
</plugin>
.....
UPDATE: set source
and target
to 1.8
, if you are using JDK 8.
a snippet on how to use the plugin to cross-compilte would be very good instead of visiting/opening the link
– coding_idiot
Nov 1 '14 at 9:39
add a comment |
I had the same error message when running Ant from Eclipse, but the other solutions mentioned here didn't solve my problem. The funny thing was that running Ant from the Windows command line was running fine, so it had to be a configuration issue within Eclipse.
It turned out that under Eclipse you can specify the environment that Ant should be running with and this was set as a JRE instead of a JDK.
- Go to: Run -> External Tools -> External Tools Configurations ...
- Select the Ant build.xml for your project (if you have multiple projects)
- Activate the Tab 'JRE'
- Here was selected 'Separate JRE: jre6'. When I changed this to a JDK from the 1.6 or 1.7 series, the error was gone.
add a comment |
How do I fix it?
This error means that the JRE that is being used to execute your class code does not recognise the version of Java used. Usually because the version of Java that generated your class file (i.e. compiled it) is newer.
To fix it, you can either
a) Compile your Java sources with the same, or older, version of the Java compiler as will be used to run it. i.e. install the appropriate JDK.
b) Compile your Java sources with the newer version of the Java compiler but in compatibility mode. i.e. use the -target
parameter.
c) Run your compiled classes in a JRE that is the same, or newer, version as the JDK used to compile the classes.
You can check the versions you are currently using with
javac -version
for the compiler, and java -version
for the runtime.
Should I install the JDK, and setup my PATH variable to the JDK
instead of JRE?
For compilation, certainly, install and configure the specific JDK that you want.
For runtime, you can use the one that comes with the JDK or a standalone JRE, but regardless, make sure that you have installed the right versions and that you have configured your PATH such that there are no surprises.
What is the difference between the PATH variable in JRE or JDK?
The PATH environment variable tells the command shell where to look for the command you type. When you type java
, the command shell interpreter will look through all the locations specified in the PATH
variable, from left to right, to find the appropriate java
runtime executable to run. If you have multiple versions of Java installed - i.e. you have the java
executable in multiple locations specified in the PATH variable, then the first one encountered when going from left to right will be the one that is executed.
The compiler command is javac
and only comes with the JDK. The runtime command is java
and comes with the JDK and is in the JRE.
It is likely that you have one version (51.0 = Java 7) of javac
installed, and you also have the same version of java
installed, but that another previous version of java
is appearing earlier in the PATH and so is being invoked instead of the one you expect.
add a comment |
You have used a higher version of the JDK to compile and trying to run from a lower version of JDK/JRE.
To check this, see the version information:
javac -version
java -version
They will be different and javac will have a higher version number.
To get around this, run using java from the JDK version or if you have a newer JRE/JDK that will work as well.
which javac
will tell you the location, for example, /usr/bin/javac
. Just run directly using /usr/bin/java <program>
.
OR you can set the environment variable as a permanent solution.
add a comment |
Had this problem when I reverted to Java 6 and tried to run classes previously compiled with Java 7. What worked for me was Preferences > java > compiler --> set compliance level to 1.6 and crucially "configure project settings"..
add a comment |
Today, this error message appeared in our Tomcat 7 on Ubuntu 12.04.2 LTS (Precise Pangolin):
/var/log/tomcat7/localhost.2014-04-08.log:
Apr 8, 2014 9:00:55 AM org.apache.catalina.core.StandardContext filterStart
SEVERE: Exception starting filter struts2
java.lang.UnsupportedClassVersionError: controller/ReqAccept : Unsupported major.minor version 51.0 (unable to load class controller.ReqAccept)
The Struts application is compiled with Java 7.
It turned out, someone uses "service tomcat [stop/start]" to restart Tomcat 7,
$ ps -ef | grep java
tomcat7 31783 1 32 20:13 ? 00:00:03 /usr/lib/jvm/default-java/bin/java...
$ /usr/lib/jvm/default-java/bin/java -version
java version "1.6.0_27"
Which causes the "Unsupported major.minor version 51.0" error.
When we used "/etc/init.d/tomcat7 [stop/start]" to restart Tomcat 7, the problem was solved.
$ ps -ef | grep java
tomcat7 31886 1 80 20:24 ? 00:00:10 /usr/local/java/jdk1.7.0_15/bin/java
$ /usr/local/java/jdk1.7.0_15/bin/java -version
java version "1.7.0_15"
add a comment |
I solved it. I ran:
JAVA_HOME=/usr/lib/jvm/java-7-openjdk-i386
The error is misleading, Unsupported major.minor version 51.0
. This gives the impression that version 51 (Java 7) is not supported. And we should use Java 6.
The error should have been:
The current Java version, 50, is unsupported. Use Java version 7 (51:0 and greater) instead.`
add a comment |
Your Java file is compiled with a different version (higher compiler version) than the version (lower runtime version) you are trying to run it with.
It is basic understanding that classes compiled with lower versions are expected to run in the later higher versions. But the opposite (compiled with higher compiler version and trying to run it with lower runtime version) is quite not possible sometimes.
Hence you are shown this error, when trying to execute your program. Unsupported major.minor version x.x
Q: I have created an application in Java 7, but when my users try to
run it they get an Unsupported major.minor version 51.0 error. What
does this mean and what can I do about it?
A: If you compile an application using javac in Java 7, the resulting classfiles will have the 51.0 version number. Versions of
Java prior to 7 do not recognize this number, so your users will have
to upgrade to Java 7 prior to running your application. If you are not
using any Java 7 APIs you can try to compile your application using
javac -target 1.6 to create a 1.6-compatible classfile. If your
application is deployed using webstart you can specify the minimum
version required. For more information, see the docs on Java Web Start
and JNLP here. This issue will go away once we trigger autoupdate to
Java 7 for end-users currently having Java 6 on their desktops. The
timeline for this is not yet determined, we want to give developers
time to work out any issues between their code and JDK 7 first.
(Source: oracle.com.)
add a comment |
Oh Mac OS X I was able to solve this problem by setting the JAVA_HOME variable:
export JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk1.7.0_75.jdk/Contents/Home
add a comment |
First let's get some basics right...
JRE is a component in NetBeans/Eclipse/standalone that is going to provide you with libraries, JVM, Java plugins & Java web start. Note that it does not provide compliers or debuggers.
JDK is the superset of JRE along with compliers and debuggers.
So when you have your default library as a JRE instead of JDK, you are going to have a nice time importing stuff, but it won't compile.
Instead, set your path to JDK (I use NetBeans, and I set them using netbeans.conf in netbeans/etc/netbeans.conf and change the path).
add a comment |
I had the problem whereby I was having to run a Maven compilation on my project from the command line in order to run my unit tests; if I made a change to the test class and let Eclipse automatically recompile it, then I got the "Unsupported major.minor version 51.0" error.
I do have both JDK6 and JDK7 installed, but all my JRE settings were pointing at 1.6, both in the pom and from the project properties page in Eclipse. No amount of Maven Update Project and/or refreshing solved this.
Finally I tried closing the project and re-opening it, and this seemed to fix it! HTH
add a comment |
You have compiled your Java class with JDK 7 and you are trying to run same class on JDK 6 .
add a comment |
- Install JDK 7.0.55 and set the Java for Eclipse for JDK 7.0.55.
- Build the project with JDK 7.0.55 by configuring on build path JDK 7.0.55.
- Set the compiler in Eclipse for JDK 7.0.55 by menu Windows -> Preferences -> Java -> Compiler - choose 1.7.
add a comment |
In my case the problem was in the server runtime configuration:
Check the JRE is the version you need:
The project was in version 1.7 and the server JRE was set as 1.6, after changing to the proper java version it launched fine.
add a comment |
1 2
next
protected by bummi Sep 22 '14 at 16:30
Thank you for your interest in this question.
Because it has attracted low-quality or spam answers that had to be removed, posting an answer now requires 10 reputation on this site (the association bonus does not count).
Would you like to answer one of these unanswered questions instead?
46 Answers
46
active
oldest
votes
46 Answers
46
active
oldest
votes
active
oldest
votes
active
oldest
votes
1 2
next
The version number shown describes the version of the JRE the class file is compatible with.
The reported major numbers are:
Java SE 13 = 57,
Java SE 12 = 56,
Java SE 11 = 55,
Java SE 10 = 54,
Java SE 9 = 53,
Java SE 8 = 52,
Java SE 7 = 51,
Java SE 6.0 = 50,
Java SE 5.0 = 49,
JDK 1.4 = 48,
JDK 1.3 = 47,
JDK 1.2 = 46,
JDK 1.1 = 45
(Source: Wikipedia)
To fix the actual problem you should try to either run the Java code with a newer version of Java JRE or specify the target parameter to the Java compiler to instruct the compiler to create code compatible with earlier Java versions.
For example, in order to generate class files compatible with Java 1.4, use the following command line:
javac -target 1.4 HelloWorld.java
With newer versions of the Java compiler you are likely to get a warning about the bootstrap class path not being set. More information about this error is available in blog post New javac warning for setting an older source without bootclasspath.
157
"The version number shown describe which version if Java was used to compile the code." No it does not. It shows the version of the JRE that the class file is compatible with. Using cross-compilation options you can use a 1.7 JDK to compile code with a class version of 1.1 (through 1.7).
– Andrew Thompson
Jan 10 '13 at 5:31
80
This answer does not explain how to fix it as the question asked?
– Jonathan Leung
Mar 5 '13 at 12:58
7
This is a nice solution for compiling to a previous version from Eclipse directly: stackoverflow.com/a/16345710/2091700
– Alphaaa
May 23 '13 at 14:03
19
IN eclipse project=>Proerties=>java compiler; set "the compiler compliance level" to the version according to your jre or jdk. As for me, it's 1.6 for jre 1.6
– Sam
Sep 25 '13 at 14:58
5
This may occur when compiler source is set in non-compliance with currently compiling JRE/JDK. For example i found the below values from eclipse .settings folder, org.eclipse.jdt.core.compiler.compliance=1.7, org.eclipse.jdt.core.compiler.source=1.7, org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.7. And my compiler was 1.6.0_32. The problem was resolved after changing the values to 1.6. The issue originated after i copied the project from a different workspace where i was using JDK 1.7 :(
– Gana
Dec 22 '14 at 6:22
|
show 4 more comments
The version number shown describes the version of the JRE the class file is compatible with.
The reported major numbers are:
Java SE 13 = 57,
Java SE 12 = 56,
Java SE 11 = 55,
Java SE 10 = 54,
Java SE 9 = 53,
Java SE 8 = 52,
Java SE 7 = 51,
Java SE 6.0 = 50,
Java SE 5.0 = 49,
JDK 1.4 = 48,
JDK 1.3 = 47,
JDK 1.2 = 46,
JDK 1.1 = 45
(Source: Wikipedia)
To fix the actual problem you should try to either run the Java code with a newer version of Java JRE or specify the target parameter to the Java compiler to instruct the compiler to create code compatible with earlier Java versions.
For example, in order to generate class files compatible with Java 1.4, use the following command line:
javac -target 1.4 HelloWorld.java
With newer versions of the Java compiler you are likely to get a warning about the bootstrap class path not being set. More information about this error is available in blog post New javac warning for setting an older source without bootclasspath.
157
"The version number shown describe which version if Java was used to compile the code." No it does not. It shows the version of the JRE that the class file is compatible with. Using cross-compilation options you can use a 1.7 JDK to compile code with a class version of 1.1 (through 1.7).
– Andrew Thompson
Jan 10 '13 at 5:31
80
This answer does not explain how to fix it as the question asked?
– Jonathan Leung
Mar 5 '13 at 12:58
7
This is a nice solution for compiling to a previous version from Eclipse directly: stackoverflow.com/a/16345710/2091700
– Alphaaa
May 23 '13 at 14:03
19
IN eclipse project=>Proerties=>java compiler; set "the compiler compliance level" to the version according to your jre or jdk. As for me, it's 1.6 for jre 1.6
– Sam
Sep 25 '13 at 14:58
5
This may occur when compiler source is set in non-compliance with currently compiling JRE/JDK. For example i found the below values from eclipse .settings folder, org.eclipse.jdt.core.compiler.compliance=1.7, org.eclipse.jdt.core.compiler.source=1.7, org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.7. And my compiler was 1.6.0_32. The problem was resolved after changing the values to 1.6. The issue originated after i copied the project from a different workspace where i was using JDK 1.7 :(
– Gana
Dec 22 '14 at 6:22
|
show 4 more comments
The version number shown describes the version of the JRE the class file is compatible with.
The reported major numbers are:
Java SE 13 = 57,
Java SE 12 = 56,
Java SE 11 = 55,
Java SE 10 = 54,
Java SE 9 = 53,
Java SE 8 = 52,
Java SE 7 = 51,
Java SE 6.0 = 50,
Java SE 5.0 = 49,
JDK 1.4 = 48,
JDK 1.3 = 47,
JDK 1.2 = 46,
JDK 1.1 = 45
(Source: Wikipedia)
To fix the actual problem you should try to either run the Java code with a newer version of Java JRE or specify the target parameter to the Java compiler to instruct the compiler to create code compatible with earlier Java versions.
For example, in order to generate class files compatible with Java 1.4, use the following command line:
javac -target 1.4 HelloWorld.java
With newer versions of the Java compiler you are likely to get a warning about the bootstrap class path not being set. More information about this error is available in blog post New javac warning for setting an older source without bootclasspath.
The version number shown describes the version of the JRE the class file is compatible with.
The reported major numbers are:
Java SE 13 = 57,
Java SE 12 = 56,
Java SE 11 = 55,
Java SE 10 = 54,
Java SE 9 = 53,
Java SE 8 = 52,
Java SE 7 = 51,
Java SE 6.0 = 50,
Java SE 5.0 = 49,
JDK 1.4 = 48,
JDK 1.3 = 47,
JDK 1.2 = 46,
JDK 1.1 = 45
(Source: Wikipedia)
To fix the actual problem you should try to either run the Java code with a newer version of Java JRE or specify the target parameter to the Java compiler to instruct the compiler to create code compatible with earlier Java versions.
For example, in order to generate class files compatible with Java 1.4, use the following command line:
javac -target 1.4 HelloWorld.java
With newer versions of the Java compiler you are likely to get a warning about the bootstrap class path not being set. More information about this error is available in blog post New javac warning for setting an older source without bootclasspath.
edited Feb 8 at 12:14
cod-e-rection
520318
520318
answered Jul 11 '12 at 11:59
Juha PalomäkiJuha Palomäki
22.3k22938
22.3k22938
157
"The version number shown describe which version if Java was used to compile the code." No it does not. It shows the version of the JRE that the class file is compatible with. Using cross-compilation options you can use a 1.7 JDK to compile code with a class version of 1.1 (through 1.7).
– Andrew Thompson
Jan 10 '13 at 5:31
80
This answer does not explain how to fix it as the question asked?
– Jonathan Leung
Mar 5 '13 at 12:58
7
This is a nice solution for compiling to a previous version from Eclipse directly: stackoverflow.com/a/16345710/2091700
– Alphaaa
May 23 '13 at 14:03
19
IN eclipse project=>Proerties=>java compiler; set "the compiler compliance level" to the version according to your jre or jdk. As for me, it's 1.6 for jre 1.6
– Sam
Sep 25 '13 at 14:58
5
This may occur when compiler source is set in non-compliance with currently compiling JRE/JDK. For example i found the below values from eclipse .settings folder, org.eclipse.jdt.core.compiler.compliance=1.7, org.eclipse.jdt.core.compiler.source=1.7, org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.7. And my compiler was 1.6.0_32. The problem was resolved after changing the values to 1.6. The issue originated after i copied the project from a different workspace where i was using JDK 1.7 :(
– Gana
Dec 22 '14 at 6:22
|
show 4 more comments
157
"The version number shown describe which version if Java was used to compile the code." No it does not. It shows the version of the JRE that the class file is compatible with. Using cross-compilation options you can use a 1.7 JDK to compile code with a class version of 1.1 (through 1.7).
– Andrew Thompson
Jan 10 '13 at 5:31
80
This answer does not explain how to fix it as the question asked?
– Jonathan Leung
Mar 5 '13 at 12:58
7
This is a nice solution for compiling to a previous version from Eclipse directly: stackoverflow.com/a/16345710/2091700
– Alphaaa
May 23 '13 at 14:03
19
IN eclipse project=>Proerties=>java compiler; set "the compiler compliance level" to the version according to your jre or jdk. As for me, it's 1.6 for jre 1.6
– Sam
Sep 25 '13 at 14:58
5
This may occur when compiler source is set in non-compliance with currently compiling JRE/JDK. For example i found the below values from eclipse .settings folder, org.eclipse.jdt.core.compiler.compliance=1.7, org.eclipse.jdt.core.compiler.source=1.7, org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.7. And my compiler was 1.6.0_32. The problem was resolved after changing the values to 1.6. The issue originated after i copied the project from a different workspace where i was using JDK 1.7 :(
– Gana
Dec 22 '14 at 6:22
157
157
"The version number shown describe which version if Java was used to compile the code." No it does not. It shows the version of the JRE that the class file is compatible with. Using cross-compilation options you can use a 1.7 JDK to compile code with a class version of 1.1 (through 1.7).
– Andrew Thompson
Jan 10 '13 at 5:31
"The version number shown describe which version if Java was used to compile the code." No it does not. It shows the version of the JRE that the class file is compatible with. Using cross-compilation options you can use a 1.7 JDK to compile code with a class version of 1.1 (through 1.7).
– Andrew Thompson
Jan 10 '13 at 5:31
80
80
This answer does not explain how to fix it as the question asked?
– Jonathan Leung
Mar 5 '13 at 12:58
This answer does not explain how to fix it as the question asked?
– Jonathan Leung
Mar 5 '13 at 12:58
7
7
This is a nice solution for compiling to a previous version from Eclipse directly: stackoverflow.com/a/16345710/2091700
– Alphaaa
May 23 '13 at 14:03
This is a nice solution for compiling to a previous version from Eclipse directly: stackoverflow.com/a/16345710/2091700
– Alphaaa
May 23 '13 at 14:03
19
19
IN eclipse project=>Proerties=>java compiler; set "the compiler compliance level" to the version according to your jre or jdk. As for me, it's 1.6 for jre 1.6
– Sam
Sep 25 '13 at 14:58
IN eclipse project=>Proerties=>java compiler; set "the compiler compliance level" to the version according to your jre or jdk. As for me, it's 1.6 for jre 1.6
– Sam
Sep 25 '13 at 14:58
5
5
This may occur when compiler source is set in non-compliance with currently compiling JRE/JDK. For example i found the below values from eclipse .settings folder, org.eclipse.jdt.core.compiler.compliance=1.7, org.eclipse.jdt.core.compiler.source=1.7, org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.7. And my compiler was 1.6.0_32. The problem was resolved after changing the values to 1.6. The issue originated after i copied the project from a different workspace where i was using JDK 1.7 :(
– Gana
Dec 22 '14 at 6:22
This may occur when compiler source is set in non-compliance with currently compiling JRE/JDK. For example i found the below values from eclipse .settings folder, org.eclipse.jdt.core.compiler.compliance=1.7, org.eclipse.jdt.core.compiler.source=1.7, org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.7. And my compiler was 1.6.0_32. The problem was resolved after changing the values to 1.6. The issue originated after i copied the project from a different workspace where i was using JDK 1.7 :(
– Gana
Dec 22 '14 at 6:22
|
show 4 more comments
java.lang.UnsupportedClassVersionError
happens because of a higher JDK during compile time and lower JDK during runtime.
10
+1: changing this symbolic link (/etc/alternatives/java -> /usr/lib/jvm/java-6-openjdk-amd64/jre/bin/java
) to the version used for compilation with javac solved it
– ezdazuzena
Aug 6 '13 at 9:30
1
How can i make above change?
– Ankur Raiyani
Aug 14 '13 at 12:57
7
Project -> Properties -> Java Compiler Enable project specific settings. Then select Compiler Compliance Level to 1.7, 1.6 or 1.5, build and test your app.
– Vivek Kumar Ray
Aug 16 '13 at 9:55
More details please see the link vivekraicdac.blogspot.in
– Vivek Kumar Ray
Aug 16 '13 at 9:56
8
@ezdazuzena usesudo update-alternatives --config java
to do so.
– Thorbjørn Ravn Andersen
Jan 29 '14 at 10:06
|
show 4 more comments
java.lang.UnsupportedClassVersionError
happens because of a higher JDK during compile time and lower JDK during runtime.
10
+1: changing this symbolic link (/etc/alternatives/java -> /usr/lib/jvm/java-6-openjdk-amd64/jre/bin/java
) to the version used for compilation with javac solved it
– ezdazuzena
Aug 6 '13 at 9:30
1
How can i make above change?
– Ankur Raiyani
Aug 14 '13 at 12:57
7
Project -> Properties -> Java Compiler Enable project specific settings. Then select Compiler Compliance Level to 1.7, 1.6 or 1.5, build and test your app.
– Vivek Kumar Ray
Aug 16 '13 at 9:55
More details please see the link vivekraicdac.blogspot.in
– Vivek Kumar Ray
Aug 16 '13 at 9:56
8
@ezdazuzena usesudo update-alternatives --config java
to do so.
– Thorbjørn Ravn Andersen
Jan 29 '14 at 10:06
|
show 4 more comments
java.lang.UnsupportedClassVersionError
happens because of a higher JDK during compile time and lower JDK during runtime.
java.lang.UnsupportedClassVersionError
happens because of a higher JDK during compile time and lower JDK during runtime.
answered Jun 28 '12 at 6:48
Vivek Kumar RayVivek Kumar Ray
6,50431527
6,50431527
10
+1: changing this symbolic link (/etc/alternatives/java -> /usr/lib/jvm/java-6-openjdk-amd64/jre/bin/java
) to the version used for compilation with javac solved it
– ezdazuzena
Aug 6 '13 at 9:30
1
How can i make above change?
– Ankur Raiyani
Aug 14 '13 at 12:57
7
Project -> Properties -> Java Compiler Enable project specific settings. Then select Compiler Compliance Level to 1.7, 1.6 or 1.5, build and test your app.
– Vivek Kumar Ray
Aug 16 '13 at 9:55
More details please see the link vivekraicdac.blogspot.in
– Vivek Kumar Ray
Aug 16 '13 at 9:56
8
@ezdazuzena usesudo update-alternatives --config java
to do so.
– Thorbjørn Ravn Andersen
Jan 29 '14 at 10:06
|
show 4 more comments
10
+1: changing this symbolic link (/etc/alternatives/java -> /usr/lib/jvm/java-6-openjdk-amd64/jre/bin/java
) to the version used for compilation with javac solved it
– ezdazuzena
Aug 6 '13 at 9:30
1
How can i make above change?
– Ankur Raiyani
Aug 14 '13 at 12:57
7
Project -> Properties -> Java Compiler Enable project specific settings. Then select Compiler Compliance Level to 1.7, 1.6 or 1.5, build and test your app.
– Vivek Kumar Ray
Aug 16 '13 at 9:55
More details please see the link vivekraicdac.blogspot.in
– Vivek Kumar Ray
Aug 16 '13 at 9:56
8
@ezdazuzena usesudo update-alternatives --config java
to do so.
– Thorbjørn Ravn Andersen
Jan 29 '14 at 10:06
10
10
+1: changing this symbolic link (
/etc/alternatives/java -> /usr/lib/jvm/java-6-openjdk-amd64/jre/bin/java
) to the version used for compilation with javac solved it– ezdazuzena
Aug 6 '13 at 9:30
+1: changing this symbolic link (
/etc/alternatives/java -> /usr/lib/jvm/java-6-openjdk-amd64/jre/bin/java
) to the version used for compilation with javac solved it– ezdazuzena
Aug 6 '13 at 9:30
1
1
How can i make above change?
– Ankur Raiyani
Aug 14 '13 at 12:57
How can i make above change?
– Ankur Raiyani
Aug 14 '13 at 12:57
7
7
Project -> Properties -> Java Compiler Enable project specific settings. Then select Compiler Compliance Level to 1.7, 1.6 or 1.5, build and test your app.
– Vivek Kumar Ray
Aug 16 '13 at 9:55
Project -> Properties -> Java Compiler Enable project specific settings. Then select Compiler Compliance Level to 1.7, 1.6 or 1.5, build and test your app.
– Vivek Kumar Ray
Aug 16 '13 at 9:55
More details please see the link vivekraicdac.blogspot.in
– Vivek Kumar Ray
Aug 16 '13 at 9:56
More details please see the link vivekraicdac.blogspot.in
– Vivek Kumar Ray
Aug 16 '13 at 9:56
8
8
@ezdazuzena use
sudo update-alternatives --config java
to do so.– Thorbjørn Ravn Andersen
Jan 29 '14 at 10:06
@ezdazuzena use
sudo update-alternatives --config java
to do so.– Thorbjørn Ravn Andersen
Jan 29 '14 at 10:06
|
show 4 more comments
In Eclipse, I just went to menu command Window -> Preferences -> Java -> Compiler and then set "Compiler compliance level" to 1.6.
3
In eclipse, sometime project facets also need to be changed to appropriate java version.
– Bilal Mirza
Jul 4 '13 at 7:59
6
Thanks. It's worth noting that setting Eclipse's default execution environment (the JRE that goes on the build path) is a separate setting. I had set the JRE but not the compiler compliance level; this fixed it.
– wchargin
Jan 26 '14 at 1:52
And how did you draw the conclusion from the error message that this was the right place to set the option?
– Alexander
Oct 24 '15 at 13:37
Maybe this: stackoverflow.com/questions/7073485/… can help if you are using ant and eclipse.
– OuuGiii
Aug 2 '17 at 7:46
add a comment |
In Eclipse, I just went to menu command Window -> Preferences -> Java -> Compiler and then set "Compiler compliance level" to 1.6.
3
In eclipse, sometime project facets also need to be changed to appropriate java version.
– Bilal Mirza
Jul 4 '13 at 7:59
6
Thanks. It's worth noting that setting Eclipse's default execution environment (the JRE that goes on the build path) is a separate setting. I had set the JRE but not the compiler compliance level; this fixed it.
– wchargin
Jan 26 '14 at 1:52
And how did you draw the conclusion from the error message that this was the right place to set the option?
– Alexander
Oct 24 '15 at 13:37
Maybe this: stackoverflow.com/questions/7073485/… can help if you are using ant and eclipse.
– OuuGiii
Aug 2 '17 at 7:46
add a comment |
In Eclipse, I just went to menu command Window -> Preferences -> Java -> Compiler and then set "Compiler compliance level" to 1.6.
In Eclipse, I just went to menu command Window -> Preferences -> Java -> Compiler and then set "Compiler compliance level" to 1.6.
edited Jul 23 '14 at 18:34
Peter Mortensen
13.7k1986112
13.7k1986112
answered May 2 '13 at 18:58
CacovskyCacovsky
2,17921725
2,17921725
3
In eclipse, sometime project facets also need to be changed to appropriate java version.
– Bilal Mirza
Jul 4 '13 at 7:59
6
Thanks. It's worth noting that setting Eclipse's default execution environment (the JRE that goes on the build path) is a separate setting. I had set the JRE but not the compiler compliance level; this fixed it.
– wchargin
Jan 26 '14 at 1:52
And how did you draw the conclusion from the error message that this was the right place to set the option?
– Alexander
Oct 24 '15 at 13:37
Maybe this: stackoverflow.com/questions/7073485/… can help if you are using ant and eclipse.
– OuuGiii
Aug 2 '17 at 7:46
add a comment |
3
In eclipse, sometime project facets also need to be changed to appropriate java version.
– Bilal Mirza
Jul 4 '13 at 7:59
6
Thanks. It's worth noting that setting Eclipse's default execution environment (the JRE that goes on the build path) is a separate setting. I had set the JRE but not the compiler compliance level; this fixed it.
– wchargin
Jan 26 '14 at 1:52
And how did you draw the conclusion from the error message that this was the right place to set the option?
– Alexander
Oct 24 '15 at 13:37
Maybe this: stackoverflow.com/questions/7073485/… can help if you are using ant and eclipse.
– OuuGiii
Aug 2 '17 at 7:46
3
3
In eclipse, sometime project facets also need to be changed to appropriate java version.
– Bilal Mirza
Jul 4 '13 at 7:59
In eclipse, sometime project facets also need to be changed to appropriate java version.
– Bilal Mirza
Jul 4 '13 at 7:59
6
6
Thanks. It's worth noting that setting Eclipse's default execution environment (the JRE that goes on the build path) is a separate setting. I had set the JRE but not the compiler compliance level; this fixed it.
– wchargin
Jan 26 '14 at 1:52
Thanks. It's worth noting that setting Eclipse's default execution environment (the JRE that goes on the build path) is a separate setting. I had set the JRE but not the compiler compliance level; this fixed it.
– wchargin
Jan 26 '14 at 1:52
And how did you draw the conclusion from the error message that this was the right place to set the option?
– Alexander
Oct 24 '15 at 13:37
And how did you draw the conclusion from the error message that this was the right place to set the option?
– Alexander
Oct 24 '15 at 13:37
Maybe this: stackoverflow.com/questions/7073485/… can help if you are using ant and eclipse.
– OuuGiii
Aug 2 '17 at 7:46
Maybe this: stackoverflow.com/questions/7073485/… can help if you are using ant and eclipse.
– OuuGiii
Aug 2 '17 at 7:46
add a comment |
Don't worry, I got it solved.
It is actually simple - you need to install BOTH JRE / JDK with the same version.
JRE 6 -> JDK 6
JRE 7 -> JDK 7
And so on.
25
java 7 can handle 6 without any problems too.
– damienix
Oct 31 '13 at 10:23
add a comment |
Don't worry, I got it solved.
It is actually simple - you need to install BOTH JRE / JDK with the same version.
JRE 6 -> JDK 6
JRE 7 -> JDK 7
And so on.
25
java 7 can handle 6 without any problems too.
– damienix
Oct 31 '13 at 10:23
add a comment |
Don't worry, I got it solved.
It is actually simple - you need to install BOTH JRE / JDK with the same version.
JRE 6 -> JDK 6
JRE 7 -> JDK 7
And so on.
Don't worry, I got it solved.
It is actually simple - you need to install BOTH JRE / JDK with the same version.
JRE 6 -> JDK 6
JRE 7 -> JDK 7
And so on.
edited Jul 12 '14 at 20:22
Peter Mortensen
13.7k1986112
13.7k1986112
answered May 4 '12 at 6:23
ERJANERJAN
9,370123468
9,370123468
25
java 7 can handle 6 without any problems too.
– damienix
Oct 31 '13 at 10:23
add a comment |
25
java 7 can handle 6 without any problems too.
– damienix
Oct 31 '13 at 10:23
25
25
java 7 can handle 6 without any problems too.
– damienix
Oct 31 '13 at 10:23
java 7 can handle 6 without any problems too.
– damienix
Oct 31 '13 at 10:23
add a comment |
This error means you're trying to load a Java "class" file that was compiled with a newer version of Java than you have installed.
For example, your .class
file could have been compiled for JDK 7, and you're trying to run it with JDK 6.
So the solution is to either:
- Upgrade your Java runtime or
Recompile the class if you have the source, using your local Java compiler (if you have one).
javac FileName.java
For developers, this can happen if another developer checks in a .class file, and they've got a newer version of java than you have!
4
Except inside jars.
– Chris
Feb 12 '15 at 18:31
add a comment |
This error means you're trying to load a Java "class" file that was compiled with a newer version of Java than you have installed.
For example, your .class
file could have been compiled for JDK 7, and you're trying to run it with JDK 6.
So the solution is to either:
- Upgrade your Java runtime or
Recompile the class if you have the source, using your local Java compiler (if you have one).
javac FileName.java
For developers, this can happen if another developer checks in a .class file, and they've got a newer version of java than you have!
4
Except inside jars.
– Chris
Feb 12 '15 at 18:31
add a comment |
This error means you're trying to load a Java "class" file that was compiled with a newer version of Java than you have installed.
For example, your .class
file could have been compiled for JDK 7, and you're trying to run it with JDK 6.
So the solution is to either:
- Upgrade your Java runtime or
Recompile the class if you have the source, using your local Java compiler (if you have one).
javac FileName.java
For developers, this can happen if another developer checks in a .class file, and they've got a newer version of java than you have!
This error means you're trying to load a Java "class" file that was compiled with a newer version of Java than you have installed.
For example, your .class
file could have been compiled for JDK 7, and you're trying to run it with JDK 6.
So the solution is to either:
- Upgrade your Java runtime or
Recompile the class if you have the source, using your local Java compiler (if you have one).
javac FileName.java
For developers, this can happen if another developer checks in a .class file, and they've got a newer version of java than you have!
edited Nov 27 '14 at 1:31
answered Feb 20 '13 at 19:02
Brad ParksBrad Parks
29.6k36166226
29.6k36166226
4
Except inside jars.
– Chris
Feb 12 '15 at 18:31
add a comment |
4
Except inside jars.
– Chris
Feb 12 '15 at 18:31
4
4
Except inside jars.
– Chris
Feb 12 '15 at 18:31
Except inside jars.
– Chris
Feb 12 '15 at 18:31
add a comment |
You are trying to run your program with a Java version that does not support the version in which the code was compiled. So basically you must have compiled your code with a higher version and trying to run it using a lower version.
As you are getting
Unsupported major.minor version 51.0
and version 51.0 corresponds to J2SE 7 you have most probably compiled your code in Java 7 and trying to run it using a lower version. Check what java -version
displays. It should be the Java 7 version. If not make appropriate changes in the PATH/JAVA_HOME. Or you can compile with the same version you are trying to run the code. If the configurations are confusing you can always give absolute path /home/user/jdk1.7.0_11/bin/javac
and /home/user/jdk1.7.0_11/bin/java
.
add a comment |
You are trying to run your program with a Java version that does not support the version in which the code was compiled. So basically you must have compiled your code with a higher version and trying to run it using a lower version.
As you are getting
Unsupported major.minor version 51.0
and version 51.0 corresponds to J2SE 7 you have most probably compiled your code in Java 7 and trying to run it using a lower version. Check what java -version
displays. It should be the Java 7 version. If not make appropriate changes in the PATH/JAVA_HOME. Or you can compile with the same version you are trying to run the code. If the configurations are confusing you can always give absolute path /home/user/jdk1.7.0_11/bin/javac
and /home/user/jdk1.7.0_11/bin/java
.
add a comment |
You are trying to run your program with a Java version that does not support the version in which the code was compiled. So basically you must have compiled your code with a higher version and trying to run it using a lower version.
As you are getting
Unsupported major.minor version 51.0
and version 51.0 corresponds to J2SE 7 you have most probably compiled your code in Java 7 and trying to run it using a lower version. Check what java -version
displays. It should be the Java 7 version. If not make appropriate changes in the PATH/JAVA_HOME. Or you can compile with the same version you are trying to run the code. If the configurations are confusing you can always give absolute path /home/user/jdk1.7.0_11/bin/javac
and /home/user/jdk1.7.0_11/bin/java
.
You are trying to run your program with a Java version that does not support the version in which the code was compiled. So basically you must have compiled your code with a higher version and trying to run it using a lower version.
As you are getting
Unsupported major.minor version 51.0
and version 51.0 corresponds to J2SE 7 you have most probably compiled your code in Java 7 and trying to run it using a lower version. Check what java -version
displays. It should be the Java 7 version. If not make appropriate changes in the PATH/JAVA_HOME. Or you can compile with the same version you are trying to run the code. If the configurations are confusing you can always give absolute path /home/user/jdk1.7.0_11/bin/javac
and /home/user/jdk1.7.0_11/bin/java
.
edited Jul 12 '14 at 20:28
Peter Mortensen
13.7k1986112
13.7k1986112
answered Oct 1 '13 at 8:51
Aniket ThakurAniket Thakur
42.3k24190213
42.3k24190213
add a comment |
add a comment |
I had a similar situation on Mac, and the following process worked for me:
In the terminal, type
vi ~/.profile
Then add this line in the file, and save
export JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk<version>.jdk/Contents/Home
where version is the one on your computer, such as 1.7.0_25
.
Exit the editor, then type the following command make it become effective
source ~/.profile
Then type java -version to check the result
java -version
What is .profile
file?
.profile file is a hidden file. It is an optional file which tells the system which commands to run when the user whose profile file it is logs in. For example, if my username is bruno and there is a .profile file in /Users/bruno/, all of its contents will be executed during the log-in procedure.
Source: http://computers.tutsplus.com/tutorials/speed-up-your-terminal-workflow-with-command-aliases-and-profile--mac-30515
add a comment |
I had a similar situation on Mac, and the following process worked for me:
In the terminal, type
vi ~/.profile
Then add this line in the file, and save
export JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk<version>.jdk/Contents/Home
where version is the one on your computer, such as 1.7.0_25
.
Exit the editor, then type the following command make it become effective
source ~/.profile
Then type java -version to check the result
java -version
What is .profile
file?
.profile file is a hidden file. It is an optional file which tells the system which commands to run when the user whose profile file it is logs in. For example, if my username is bruno and there is a .profile file in /Users/bruno/, all of its contents will be executed during the log-in procedure.
Source: http://computers.tutsplus.com/tutorials/speed-up-your-terminal-workflow-with-command-aliases-and-profile--mac-30515
add a comment |
I had a similar situation on Mac, and the following process worked for me:
In the terminal, type
vi ~/.profile
Then add this line in the file, and save
export JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk<version>.jdk/Contents/Home
where version is the one on your computer, such as 1.7.0_25
.
Exit the editor, then type the following command make it become effective
source ~/.profile
Then type java -version to check the result
java -version
What is .profile
file?
.profile file is a hidden file. It is an optional file which tells the system which commands to run when the user whose profile file it is logs in. For example, if my username is bruno and there is a .profile file in /Users/bruno/, all of its contents will be executed during the log-in procedure.
Source: http://computers.tutsplus.com/tutorials/speed-up-your-terminal-workflow-with-command-aliases-and-profile--mac-30515
I had a similar situation on Mac, and the following process worked for me:
In the terminal, type
vi ~/.profile
Then add this line in the file, and save
export JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk<version>.jdk/Contents/Home
where version is the one on your computer, such as 1.7.0_25
.
Exit the editor, then type the following command make it become effective
source ~/.profile
Then type java -version to check the result
java -version
What is .profile
file?
.profile file is a hidden file. It is an optional file which tells the system which commands to run when the user whose profile file it is logs in. For example, if my username is bruno and there is a .profile file in /Users/bruno/, all of its contents will be executed during the log-in procedure.
Source: http://computers.tutsplus.com/tutorials/speed-up-your-terminal-workflow-with-command-aliases-and-profile--mac-30515
edited Apr 4 '15 at 12:15
kenorb
68.8k29406407
68.8k29406407
answered Feb 11 '14 at 6:55
TonyTony
1,07031530
1,07031530
add a comment |
add a comment |
In Eclipse's menu Window -> Preferences -> Java -> Compiler check also "Configure Project Specific Settings".
If you stil have the error with same Java version: try to delete build folder of your project manually. Then restart Eclipse.
add a comment |
In Eclipse's menu Window -> Preferences -> Java -> Compiler check also "Configure Project Specific Settings".
If you stil have the error with same Java version: try to delete build folder of your project manually. Then restart Eclipse.
add a comment |
In Eclipse's menu Window -> Preferences -> Java -> Compiler check also "Configure Project Specific Settings".
If you stil have the error with same Java version: try to delete build folder of your project manually. Then restart Eclipse.
In Eclipse's menu Window -> Preferences -> Java -> Compiler check also "Configure Project Specific Settings".
If you stil have the error with same Java version: try to delete build folder of your project manually. Then restart Eclipse.
edited Jun 19 '15 at 11:01
answered Aug 6 '13 at 10:24
Andreas L.Andreas L.
1,8771521
1,8771521
add a comment |
add a comment |
You can have some JAR library compiled in Java 7, and you have only Java 6 as Java Runtime. It could happen with some new libraries.
add a comment |
You can have some JAR library compiled in Java 7, and you have only Java 6 as Java Runtime. It could happen with some new libraries.
add a comment |
You can have some JAR library compiled in Java 7, and you have only Java 6 as Java Runtime. It could happen with some new libraries.
You can have some JAR library compiled in Java 7, and you have only Java 6 as Java Runtime. It could happen with some new libraries.
answered Jun 25 '13 at 12:51
RioRio
48465
48465
add a comment |
add a comment |
The most common issue is misconfiguration of your JAVA_HOME
variable which should point to the right Java Development Kit library, if you've multiple installed.
To find where SDK Java folder is located, run the following commands:
jrunscript -e 'java.lang.System.out.println(java.lang.System.getProperty("java.home"));'
Debian/Ubuntu
To check which java (openjdk) you've installed, check via:
dpkg -l "openjdk*" | grep ^i
or:
update-java-alternatives -l
To change it, use:
update-alternatives --config java
Prefix with sudo
if required.
to select the alternative java version.
Or check which are available for install:
apt-cache search ^openjdk
Prefix with sudo
if required.
Then you can install, for example:
apt-get install openjdk-7-jre
Prefix with sudo
if required.
Fedora, Oracle Linux, Red Hat
Install/upgrade appropriate package via:
yum install java-1.7.0-openjdk java-1.7.0-openjdk-devel
The
java-1.7.0-openjdk
package contains just the Java Runtime Environment. If you want to develop Java programs then install thejava-1.7.0-openjdk-devel
package.
BSD
There is an OpenJDK 7 package in the FreeBSD Ports collection called openjdk7 which probably needs to be reconfigured.
See: OpenJDK wiki page.
Windows
Just install appropriate Java SE Development Kit library from the Oracle site or install
Jenkins
If you're experiencing this issue with Jenkins, see:
- JENKINS-30561 - Unable to launch agent using SSH
However selecting the right version of Java (newer) with update-alternatives
should work.
This answer worked for me when trying to use spark2-shell on a host after adding the spark service to a cluster with cloudera.
– Alter
Nov 24 '17 at 23:16
add a comment |
The most common issue is misconfiguration of your JAVA_HOME
variable which should point to the right Java Development Kit library, if you've multiple installed.
To find where SDK Java folder is located, run the following commands:
jrunscript -e 'java.lang.System.out.println(java.lang.System.getProperty("java.home"));'
Debian/Ubuntu
To check which java (openjdk) you've installed, check via:
dpkg -l "openjdk*" | grep ^i
or:
update-java-alternatives -l
To change it, use:
update-alternatives --config java
Prefix with sudo
if required.
to select the alternative java version.
Or check which are available for install:
apt-cache search ^openjdk
Prefix with sudo
if required.
Then you can install, for example:
apt-get install openjdk-7-jre
Prefix with sudo
if required.
Fedora, Oracle Linux, Red Hat
Install/upgrade appropriate package via:
yum install java-1.7.0-openjdk java-1.7.0-openjdk-devel
The
java-1.7.0-openjdk
package contains just the Java Runtime Environment. If you want to develop Java programs then install thejava-1.7.0-openjdk-devel
package.
BSD
There is an OpenJDK 7 package in the FreeBSD Ports collection called openjdk7 which probably needs to be reconfigured.
See: OpenJDK wiki page.
Windows
Just install appropriate Java SE Development Kit library from the Oracle site or install
Jenkins
If you're experiencing this issue with Jenkins, see:
- JENKINS-30561 - Unable to launch agent using SSH
However selecting the right version of Java (newer) with update-alternatives
should work.
This answer worked for me when trying to use spark2-shell on a host after adding the spark service to a cluster with cloudera.
– Alter
Nov 24 '17 at 23:16
add a comment |
The most common issue is misconfiguration of your JAVA_HOME
variable which should point to the right Java Development Kit library, if you've multiple installed.
To find where SDK Java folder is located, run the following commands:
jrunscript -e 'java.lang.System.out.println(java.lang.System.getProperty("java.home"));'
Debian/Ubuntu
To check which java (openjdk) you've installed, check via:
dpkg -l "openjdk*" | grep ^i
or:
update-java-alternatives -l
To change it, use:
update-alternatives --config java
Prefix with sudo
if required.
to select the alternative java version.
Or check which are available for install:
apt-cache search ^openjdk
Prefix with sudo
if required.
Then you can install, for example:
apt-get install openjdk-7-jre
Prefix with sudo
if required.
Fedora, Oracle Linux, Red Hat
Install/upgrade appropriate package via:
yum install java-1.7.0-openjdk java-1.7.0-openjdk-devel
The
java-1.7.0-openjdk
package contains just the Java Runtime Environment. If you want to develop Java programs then install thejava-1.7.0-openjdk-devel
package.
BSD
There is an OpenJDK 7 package in the FreeBSD Ports collection called openjdk7 which probably needs to be reconfigured.
See: OpenJDK wiki page.
Windows
Just install appropriate Java SE Development Kit library from the Oracle site or install
Jenkins
If you're experiencing this issue with Jenkins, see:
- JENKINS-30561 - Unable to launch agent using SSH
However selecting the right version of Java (newer) with update-alternatives
should work.
The most common issue is misconfiguration of your JAVA_HOME
variable which should point to the right Java Development Kit library, if you've multiple installed.
To find where SDK Java folder is located, run the following commands:
jrunscript -e 'java.lang.System.out.println(java.lang.System.getProperty("java.home"));'
Debian/Ubuntu
To check which java (openjdk) you've installed, check via:
dpkg -l "openjdk*" | grep ^i
or:
update-java-alternatives -l
To change it, use:
update-alternatives --config java
Prefix with sudo
if required.
to select the alternative java version.
Or check which are available for install:
apt-cache search ^openjdk
Prefix with sudo
if required.
Then you can install, for example:
apt-get install openjdk-7-jre
Prefix with sudo
if required.
Fedora, Oracle Linux, Red Hat
Install/upgrade appropriate package via:
yum install java-1.7.0-openjdk java-1.7.0-openjdk-devel
The
java-1.7.0-openjdk
package contains just the Java Runtime Environment. If you want to develop Java programs then install thejava-1.7.0-openjdk-devel
package.
BSD
There is an OpenJDK 7 package in the FreeBSD Ports collection called openjdk7 which probably needs to be reconfigured.
See: OpenJDK wiki page.
Windows
Just install appropriate Java SE Development Kit library from the Oracle site or install
Jenkins
If you're experiencing this issue with Jenkins, see:
- JENKINS-30561 - Unable to launch agent using SSH
However selecting the right version of Java (newer) with update-alternatives
should work.
edited Sep 20 '17 at 14:34
answered Apr 4 '15 at 12:16
kenorbkenorb
68.8k29406407
68.8k29406407
This answer worked for me when trying to use spark2-shell on a host after adding the spark service to a cluster with cloudera.
– Alter
Nov 24 '17 at 23:16
add a comment |
This answer worked for me when trying to use spark2-shell on a host after adding the spark service to a cluster with cloudera.
– Alter
Nov 24 '17 at 23:16
This answer worked for me when trying to use spark2-shell on a host after adding the spark service to a cluster with cloudera.
– Alter
Nov 24 '17 at 23:16
This answer worked for me when trying to use spark2-shell on a host after adding the spark service to a cluster with cloudera.
– Alter
Nov 24 '17 at 23:16
add a comment |
I have faced the same problem when I was working with an Ant script to build my application.
I use Eclipse for my application development, and I changed the compiler version in build properties of the project. But that didn't work for me. Then I found out that I can provide the compiler version in the Ant script.
I modified the Ant script at the section where it compile Java files.
<target name="build-java" depends="prepare-build">
<echo message="Compiling java files"/>
<javac ....
target="1.5"...
</javac>
</target>
This worked for me to resolve the unsupported major minor issue.
add a comment |
I have faced the same problem when I was working with an Ant script to build my application.
I use Eclipse for my application development, and I changed the compiler version in build properties of the project. But that didn't work for me. Then I found out that I can provide the compiler version in the Ant script.
I modified the Ant script at the section where it compile Java files.
<target name="build-java" depends="prepare-build">
<echo message="Compiling java files"/>
<javac ....
target="1.5"...
</javac>
</target>
This worked for me to resolve the unsupported major minor issue.
add a comment |
I have faced the same problem when I was working with an Ant script to build my application.
I use Eclipse for my application development, and I changed the compiler version in build properties of the project. But that didn't work for me. Then I found out that I can provide the compiler version in the Ant script.
I modified the Ant script at the section where it compile Java files.
<target name="build-java" depends="prepare-build">
<echo message="Compiling java files"/>
<javac ....
target="1.5"...
</javac>
</target>
This worked for me to resolve the unsupported major minor issue.
I have faced the same problem when I was working with an Ant script to build my application.
I use Eclipse for my application development, and I changed the compiler version in build properties of the project. But that didn't work for me. Then I found out that I can provide the compiler version in the Ant script.
I modified the Ant script at the section where it compile Java files.
<target name="build-java" depends="prepare-build">
<echo message="Compiling java files"/>
<javac ....
target="1.5"...
</javac>
</target>
This worked for me to resolve the unsupported major minor issue.
edited Jul 12 '14 at 20:29
Peter Mortensen
13.7k1986112
13.7k1986112
answered Oct 14 '13 at 3:32
Mandar PanditMandar Pandit
1,52132443
1,52132443
add a comment |
add a comment |
When I installed JDK 1.7, the problem got solved.
add a comment |
When I installed JDK 1.7, the problem got solved.
add a comment |
When I installed JDK 1.7, the problem got solved.
When I installed JDK 1.7, the problem got solved.
edited Jul 12 '14 at 20:29
Peter Mortensen
13.7k1986112
13.7k1986112
answered Jan 7 '14 at 6:43
user3168034user3168034
12112
12112
add a comment |
add a comment |
I got the same problem with a project written in 1.7 and tried to execute in 1.6.
My solution in Eclipse:
Right click on your Project Properties -> Java Build Path -> Libraries
Select your JRE System Library and click Edit on the right, and choose the target JRE.
Now go to Java Compiler on the left, and change the Compiler compliance level to your target.
That worked for me.
add a comment |
I got the same problem with a project written in 1.7 and tried to execute in 1.6.
My solution in Eclipse:
Right click on your Project Properties -> Java Build Path -> Libraries
Select your JRE System Library and click Edit on the right, and choose the target JRE.
Now go to Java Compiler on the left, and change the Compiler compliance level to your target.
That worked for me.
add a comment |
I got the same problem with a project written in 1.7 and tried to execute in 1.6.
My solution in Eclipse:
Right click on your Project Properties -> Java Build Path -> Libraries
Select your JRE System Library and click Edit on the right, and choose the target JRE.
Now go to Java Compiler on the left, and change the Compiler compliance level to your target.
That worked for me.
I got the same problem with a project written in 1.7 and tried to execute in 1.6.
My solution in Eclipse:
Right click on your Project Properties -> Java Build Path -> Libraries
Select your JRE System Library and click Edit on the right, and choose the target JRE.
Now go to Java Compiler on the left, and change the Compiler compliance level to your target.
That worked for me.
edited Nov 7 '14 at 14:28
Peter Mortensen
13.7k1986112
13.7k1986112
answered Sep 1 '14 at 8:02
BenBen
12314
12314
add a comment |
add a comment |
As answered elsewhere by several people, the Java program is being run on an older version of Java than the one it was compiled it for. It needs to be "crosscompiled" for backward compatibility. To put it another way, there is a mismatch between source and target Java versions.
Changing options in Eclipse menus don't answer the original poster, who said he/she is not using Eclipse. On OpenJDK javac version 1.7, you can crosscompile for 1.6 if you use parameters -source
and -target
, plus provide the rt.jar -file of the target version (that is, the older one) at compile time. If you actually install the 1.6 JRE, you can point to its installation (for example, /usr/lib/jvm/java-6-openjdk-i386/jre/lib/rt.jar on Ubuntu, /usr/jdk/jdk1.6.0_60/jre/lib/rt.jar on SunOS apparently. Sorry, I don't know where it is on a Windows system). Like so:
javac -source 1.6 -target 1.6 -bootclasspath /usr/lib/jvm/java-6-openjdk-i386/jre/lib/rt.jar HelloWorld.java
It looks like you can just download rt.jar from the Internet, and point to it. This is not too elegant though:
javac -source 1.6 -target 1.6 -bootclasspath ./rt.jar HelloWorld.java
add a comment |
As answered elsewhere by several people, the Java program is being run on an older version of Java than the one it was compiled it for. It needs to be "crosscompiled" for backward compatibility. To put it another way, there is a mismatch between source and target Java versions.
Changing options in Eclipse menus don't answer the original poster, who said he/she is not using Eclipse. On OpenJDK javac version 1.7, you can crosscompile for 1.6 if you use parameters -source
and -target
, plus provide the rt.jar -file of the target version (that is, the older one) at compile time. If you actually install the 1.6 JRE, you can point to its installation (for example, /usr/lib/jvm/java-6-openjdk-i386/jre/lib/rt.jar on Ubuntu, /usr/jdk/jdk1.6.0_60/jre/lib/rt.jar on SunOS apparently. Sorry, I don't know where it is on a Windows system). Like so:
javac -source 1.6 -target 1.6 -bootclasspath /usr/lib/jvm/java-6-openjdk-i386/jre/lib/rt.jar HelloWorld.java
It looks like you can just download rt.jar from the Internet, and point to it. This is not too elegant though:
javac -source 1.6 -target 1.6 -bootclasspath ./rt.jar HelloWorld.java
add a comment |
As answered elsewhere by several people, the Java program is being run on an older version of Java than the one it was compiled it for. It needs to be "crosscompiled" for backward compatibility. To put it another way, there is a mismatch between source and target Java versions.
Changing options in Eclipse menus don't answer the original poster, who said he/she is not using Eclipse. On OpenJDK javac version 1.7, you can crosscompile for 1.6 if you use parameters -source
and -target
, plus provide the rt.jar -file of the target version (that is, the older one) at compile time. If you actually install the 1.6 JRE, you can point to its installation (for example, /usr/lib/jvm/java-6-openjdk-i386/jre/lib/rt.jar on Ubuntu, /usr/jdk/jdk1.6.0_60/jre/lib/rt.jar on SunOS apparently. Sorry, I don't know where it is on a Windows system). Like so:
javac -source 1.6 -target 1.6 -bootclasspath /usr/lib/jvm/java-6-openjdk-i386/jre/lib/rt.jar HelloWorld.java
It looks like you can just download rt.jar from the Internet, and point to it. This is not too elegant though:
javac -source 1.6 -target 1.6 -bootclasspath ./rt.jar HelloWorld.java
As answered elsewhere by several people, the Java program is being run on an older version of Java than the one it was compiled it for. It needs to be "crosscompiled" for backward compatibility. To put it another way, there is a mismatch between source and target Java versions.
Changing options in Eclipse menus don't answer the original poster, who said he/she is not using Eclipse. On OpenJDK javac version 1.7, you can crosscompile for 1.6 if you use parameters -source
and -target
, plus provide the rt.jar -file of the target version (that is, the older one) at compile time. If you actually install the 1.6 JRE, you can point to its installation (for example, /usr/lib/jvm/java-6-openjdk-i386/jre/lib/rt.jar on Ubuntu, /usr/jdk/jdk1.6.0_60/jre/lib/rt.jar on SunOS apparently. Sorry, I don't know where it is on a Windows system). Like so:
javac -source 1.6 -target 1.6 -bootclasspath /usr/lib/jvm/java-6-openjdk-i386/jre/lib/rt.jar HelloWorld.java
It looks like you can just download rt.jar from the Internet, and point to it. This is not too elegant though:
javac -source 1.6 -target 1.6 -bootclasspath ./rt.jar HelloWorld.java
edited Mar 22 '16 at 21:13
CollinD
5,08421436
5,08421436
answered Sep 16 '13 at 18:25
Mace OjalaMace Ojala
13517
13517
add a comment |
add a comment |
Based on this...
J2SE 8 = 52
J2SE 7 = 51
J2SE 6.0 = 50
J2SE 5.0 = 49
JDK 1.4 = 48
JDK 1.3 = 47
JDK 1.2 = 46
JDK 1.1 = 45
In Eclipse, right click on project in package explorer:
Build Path -> Configure Build Path
Under:
Java Build Path -> Libraries -> Add Library -> JRE System Library -> Installed JREs -> Search.
Add the required JRE by selecting the library in the list available after the search is complete.
add a comment |
Based on this...
J2SE 8 = 52
J2SE 7 = 51
J2SE 6.0 = 50
J2SE 5.0 = 49
JDK 1.4 = 48
JDK 1.3 = 47
JDK 1.2 = 46
JDK 1.1 = 45
In Eclipse, right click on project in package explorer:
Build Path -> Configure Build Path
Under:
Java Build Path -> Libraries -> Add Library -> JRE System Library -> Installed JREs -> Search.
Add the required JRE by selecting the library in the list available after the search is complete.
add a comment |
Based on this...
J2SE 8 = 52
J2SE 7 = 51
J2SE 6.0 = 50
J2SE 5.0 = 49
JDK 1.4 = 48
JDK 1.3 = 47
JDK 1.2 = 46
JDK 1.1 = 45
In Eclipse, right click on project in package explorer:
Build Path -> Configure Build Path
Under:
Java Build Path -> Libraries -> Add Library -> JRE System Library -> Installed JREs -> Search.
Add the required JRE by selecting the library in the list available after the search is complete.
Based on this...
J2SE 8 = 52
J2SE 7 = 51
J2SE 6.0 = 50
J2SE 5.0 = 49
JDK 1.4 = 48
JDK 1.3 = 47
JDK 1.2 = 46
JDK 1.1 = 45
In Eclipse, right click on project in package explorer:
Build Path -> Configure Build Path
Under:
Java Build Path -> Libraries -> Add Library -> JRE System Library -> Installed JREs -> Search.
Add the required JRE by selecting the library in the list available after the search is complete.
edited Jul 12 '14 at 20:52
Peter Mortensen
13.7k1986112
13.7k1986112
answered May 28 '14 at 9:10
Adit YaAdit Ya
466616
466616
add a comment |
add a comment |
If you use Maven, set your Java compile level. Open a command line and write
java -version
for your compile level:
If you use IntelliJ IDEA, select project → File → Settings → Build Execution Deployment → Compiler → Java Compiler. Then change byte code as 1.7 like this image:
I needed to do a maven clean install as well after changing the pom.
– Joe Borysko
Sep 22 '16 at 19:15
add a comment |
If you use Maven, set your Java compile level. Open a command line and write
java -version
for your compile level:
If you use IntelliJ IDEA, select project → File → Settings → Build Execution Deployment → Compiler → Java Compiler. Then change byte code as 1.7 like this image:
I needed to do a maven clean install as well after changing the pom.
– Joe Borysko
Sep 22 '16 at 19:15
add a comment |
If you use Maven, set your Java compile level. Open a command line and write
java -version
for your compile level:
If you use IntelliJ IDEA, select project → File → Settings → Build Execution Deployment → Compiler → Java Compiler. Then change byte code as 1.7 like this image:
If you use Maven, set your Java compile level. Open a command line and write
java -version
for your compile level:
If you use IntelliJ IDEA, select project → File → Settings → Build Execution Deployment → Compiler → Java Compiler. Then change byte code as 1.7 like this image:
edited May 25 '17 at 21:02
Peter Mortensen
13.7k1986112
13.7k1986112
answered Nov 3 '15 at 8:03
ethemsulanethemsulan
1,7912019
1,7912019
I needed to do a maven clean install as well after changing the pom.
– Joe Borysko
Sep 22 '16 at 19:15
add a comment |
I needed to do a maven clean install as well after changing the pom.
– Joe Borysko
Sep 22 '16 at 19:15
I needed to do a maven clean install as well after changing the pom.
– Joe Borysko
Sep 22 '16 at 19:15
I needed to do a maven clean install as well after changing the pom.
– Joe Borysko
Sep 22 '16 at 19:15
add a comment |
If you're facing this issue while using Maven, you can cross compile your code using the plug-in Maven Compiler.
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.1</version>
<configuration>
<source>1.6</source>
<target>1.6</target>
</configuration>
</plugin>
.....
UPDATE: set source
and target
to 1.8
, if you are using JDK 8.
a snippet on how to use the plugin to cross-compilte would be very good instead of visiting/opening the link
– coding_idiot
Nov 1 '14 at 9:39
add a comment |
If you're facing this issue while using Maven, you can cross compile your code using the plug-in Maven Compiler.
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.1</version>
<configuration>
<source>1.6</source>
<target>1.6</target>
</configuration>
</plugin>
.....
UPDATE: set source
and target
to 1.8
, if you are using JDK 8.
a snippet on how to use the plugin to cross-compilte would be very good instead of visiting/opening the link
– coding_idiot
Nov 1 '14 at 9:39
add a comment |
If you're facing this issue while using Maven, you can cross compile your code using the plug-in Maven Compiler.
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.1</version>
<configuration>
<source>1.6</source>
<target>1.6</target>
</configuration>
</plugin>
.....
UPDATE: set source
and target
to 1.8
, if you are using JDK 8.
If you're facing this issue while using Maven, you can cross compile your code using the plug-in Maven Compiler.
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.1</version>
<configuration>
<source>1.6</source>
<target>1.6</target>
</configuration>
</plugin>
.....
UPDATE: set source
and target
to 1.8
, if you are using JDK 8.
edited Mar 30 '18 at 20:33
answered Mar 10 '14 at 11:01
Thamme GowdaThamme Gowda
6,70212943
6,70212943
a snippet on how to use the plugin to cross-compilte would be very good instead of visiting/opening the link
– coding_idiot
Nov 1 '14 at 9:39
add a comment |
a snippet on how to use the plugin to cross-compilte would be very good instead of visiting/opening the link
– coding_idiot
Nov 1 '14 at 9:39
a snippet on how to use the plugin to cross-compilte would be very good instead of visiting/opening the link
– coding_idiot
Nov 1 '14 at 9:39
a snippet on how to use the plugin to cross-compilte would be very good instead of visiting/opening the link
– coding_idiot
Nov 1 '14 at 9:39
add a comment |
I had the same error message when running Ant from Eclipse, but the other solutions mentioned here didn't solve my problem. The funny thing was that running Ant from the Windows command line was running fine, so it had to be a configuration issue within Eclipse.
It turned out that under Eclipse you can specify the environment that Ant should be running with and this was set as a JRE instead of a JDK.
- Go to: Run -> External Tools -> External Tools Configurations ...
- Select the Ant build.xml for your project (if you have multiple projects)
- Activate the Tab 'JRE'
- Here was selected 'Separate JRE: jre6'. When I changed this to a JDK from the 1.6 or 1.7 series, the error was gone.
add a comment |
I had the same error message when running Ant from Eclipse, but the other solutions mentioned here didn't solve my problem. The funny thing was that running Ant from the Windows command line was running fine, so it had to be a configuration issue within Eclipse.
It turned out that under Eclipse you can specify the environment that Ant should be running with and this was set as a JRE instead of a JDK.
- Go to: Run -> External Tools -> External Tools Configurations ...
- Select the Ant build.xml for your project (if you have multiple projects)
- Activate the Tab 'JRE'
- Here was selected 'Separate JRE: jre6'. When I changed this to a JDK from the 1.6 or 1.7 series, the error was gone.
add a comment |
I had the same error message when running Ant from Eclipse, but the other solutions mentioned here didn't solve my problem. The funny thing was that running Ant from the Windows command line was running fine, so it had to be a configuration issue within Eclipse.
It turned out that under Eclipse you can specify the environment that Ant should be running with and this was set as a JRE instead of a JDK.
- Go to: Run -> External Tools -> External Tools Configurations ...
- Select the Ant build.xml for your project (if you have multiple projects)
- Activate the Tab 'JRE'
- Here was selected 'Separate JRE: jre6'. When I changed this to a JDK from the 1.6 or 1.7 series, the error was gone.
I had the same error message when running Ant from Eclipse, but the other solutions mentioned here didn't solve my problem. The funny thing was that running Ant from the Windows command line was running fine, so it had to be a configuration issue within Eclipse.
It turned out that under Eclipse you can specify the environment that Ant should be running with and this was set as a JRE instead of a JDK.
- Go to: Run -> External Tools -> External Tools Configurations ...
- Select the Ant build.xml for your project (if you have multiple projects)
- Activate the Tab 'JRE'
- Here was selected 'Separate JRE: jre6'. When I changed this to a JDK from the 1.6 or 1.7 series, the error was gone.
edited Jul 12 '14 at 20:43
Peter Mortensen
13.7k1986112
13.7k1986112
answered Feb 11 '14 at 10:36
ckielstrackielstra
9314
9314
add a comment |
add a comment |
How do I fix it?
This error means that the JRE that is being used to execute your class code does not recognise the version of Java used. Usually because the version of Java that generated your class file (i.e. compiled it) is newer.
To fix it, you can either
a) Compile your Java sources with the same, or older, version of the Java compiler as will be used to run it. i.e. install the appropriate JDK.
b) Compile your Java sources with the newer version of the Java compiler but in compatibility mode. i.e. use the -target
parameter.
c) Run your compiled classes in a JRE that is the same, or newer, version as the JDK used to compile the classes.
You can check the versions you are currently using with
javac -version
for the compiler, and java -version
for the runtime.
Should I install the JDK, and setup my PATH variable to the JDK
instead of JRE?
For compilation, certainly, install and configure the specific JDK that you want.
For runtime, you can use the one that comes with the JDK or a standalone JRE, but regardless, make sure that you have installed the right versions and that you have configured your PATH such that there are no surprises.
What is the difference between the PATH variable in JRE or JDK?
The PATH environment variable tells the command shell where to look for the command you type. When you type java
, the command shell interpreter will look through all the locations specified in the PATH
variable, from left to right, to find the appropriate java
runtime executable to run. If you have multiple versions of Java installed - i.e. you have the java
executable in multiple locations specified in the PATH variable, then the first one encountered when going from left to right will be the one that is executed.
The compiler command is javac
and only comes with the JDK. The runtime command is java
and comes with the JDK and is in the JRE.
It is likely that you have one version (51.0 = Java 7) of javac
installed, and you also have the same version of java
installed, but that another previous version of java
is appearing earlier in the PATH and so is being invoked instead of the one you expect.
add a comment |
How do I fix it?
This error means that the JRE that is being used to execute your class code does not recognise the version of Java used. Usually because the version of Java that generated your class file (i.e. compiled it) is newer.
To fix it, you can either
a) Compile your Java sources with the same, or older, version of the Java compiler as will be used to run it. i.e. install the appropriate JDK.
b) Compile your Java sources with the newer version of the Java compiler but in compatibility mode. i.e. use the -target
parameter.
c) Run your compiled classes in a JRE that is the same, or newer, version as the JDK used to compile the classes.
You can check the versions you are currently using with
javac -version
for the compiler, and java -version
for the runtime.
Should I install the JDK, and setup my PATH variable to the JDK
instead of JRE?
For compilation, certainly, install and configure the specific JDK that you want.
For runtime, you can use the one that comes with the JDK or a standalone JRE, but regardless, make sure that you have installed the right versions and that you have configured your PATH such that there are no surprises.
What is the difference between the PATH variable in JRE or JDK?
The PATH environment variable tells the command shell where to look for the command you type. When you type java
, the command shell interpreter will look through all the locations specified in the PATH
variable, from left to right, to find the appropriate java
runtime executable to run. If you have multiple versions of Java installed - i.e. you have the java
executable in multiple locations specified in the PATH variable, then the first one encountered when going from left to right will be the one that is executed.
The compiler command is javac
and only comes with the JDK. The runtime command is java
and comes with the JDK and is in the JRE.
It is likely that you have one version (51.0 = Java 7) of javac
installed, and you also have the same version of java
installed, but that another previous version of java
is appearing earlier in the PATH and so is being invoked instead of the one you expect.
add a comment |
How do I fix it?
This error means that the JRE that is being used to execute your class code does not recognise the version of Java used. Usually because the version of Java that generated your class file (i.e. compiled it) is newer.
To fix it, you can either
a) Compile your Java sources with the same, or older, version of the Java compiler as will be used to run it. i.e. install the appropriate JDK.
b) Compile your Java sources with the newer version of the Java compiler but in compatibility mode. i.e. use the -target
parameter.
c) Run your compiled classes in a JRE that is the same, or newer, version as the JDK used to compile the classes.
You can check the versions you are currently using with
javac -version
for the compiler, and java -version
for the runtime.
Should I install the JDK, and setup my PATH variable to the JDK
instead of JRE?
For compilation, certainly, install and configure the specific JDK that you want.
For runtime, you can use the one that comes with the JDK or a standalone JRE, but regardless, make sure that you have installed the right versions and that you have configured your PATH such that there are no surprises.
What is the difference between the PATH variable in JRE or JDK?
The PATH environment variable tells the command shell where to look for the command you type. When you type java
, the command shell interpreter will look through all the locations specified in the PATH
variable, from left to right, to find the appropriate java
runtime executable to run. If you have multiple versions of Java installed - i.e. you have the java
executable in multiple locations specified in the PATH variable, then the first one encountered when going from left to right will be the one that is executed.
The compiler command is javac
and only comes with the JDK. The runtime command is java
and comes with the JDK and is in the JRE.
It is likely that you have one version (51.0 = Java 7) of javac
installed, and you also have the same version of java
installed, but that another previous version of java
is appearing earlier in the PATH and so is being invoked instead of the one you expect.
How do I fix it?
This error means that the JRE that is being used to execute your class code does not recognise the version of Java used. Usually because the version of Java that generated your class file (i.e. compiled it) is newer.
To fix it, you can either
a) Compile your Java sources with the same, or older, version of the Java compiler as will be used to run it. i.e. install the appropriate JDK.
b) Compile your Java sources with the newer version of the Java compiler but in compatibility mode. i.e. use the -target
parameter.
c) Run your compiled classes in a JRE that is the same, or newer, version as the JDK used to compile the classes.
You can check the versions you are currently using with
javac -version
for the compiler, and java -version
for the runtime.
Should I install the JDK, and setup my PATH variable to the JDK
instead of JRE?
For compilation, certainly, install and configure the specific JDK that you want.
For runtime, you can use the one that comes with the JDK or a standalone JRE, but regardless, make sure that you have installed the right versions and that you have configured your PATH such that there are no surprises.
What is the difference between the PATH variable in JRE or JDK?
The PATH environment variable tells the command shell where to look for the command you type. When you type java
, the command shell interpreter will look through all the locations specified in the PATH
variable, from left to right, to find the appropriate java
runtime executable to run. If you have multiple versions of Java installed - i.e. you have the java
executable in multiple locations specified in the PATH variable, then the first one encountered when going from left to right will be the one that is executed.
The compiler command is javac
and only comes with the JDK. The runtime command is java
and comes with the JDK and is in the JRE.
It is likely that you have one version (51.0 = Java 7) of javac
installed, and you also have the same version of java
installed, but that another previous version of java
is appearing earlier in the PATH and so is being invoked instead of the one you expect.
edited Nov 18 '16 at 12:19
answered Mar 26 '15 at 9:42
VihungVihung
5,916134566
5,916134566
add a comment |
add a comment |
You have used a higher version of the JDK to compile and trying to run from a lower version of JDK/JRE.
To check this, see the version information:
javac -version
java -version
They will be different and javac will have a higher version number.
To get around this, run using java from the JDK version or if you have a newer JRE/JDK that will work as well.
which javac
will tell you the location, for example, /usr/bin/javac
. Just run directly using /usr/bin/java <program>
.
OR you can set the environment variable as a permanent solution.
add a comment |
You have used a higher version of the JDK to compile and trying to run from a lower version of JDK/JRE.
To check this, see the version information:
javac -version
java -version
They will be different and javac will have a higher version number.
To get around this, run using java from the JDK version or if you have a newer JRE/JDK that will work as well.
which javac
will tell you the location, for example, /usr/bin/javac
. Just run directly using /usr/bin/java <program>
.
OR you can set the environment variable as a permanent solution.
add a comment |
You have used a higher version of the JDK to compile and trying to run from a lower version of JDK/JRE.
To check this, see the version information:
javac -version
java -version
They will be different and javac will have a higher version number.
To get around this, run using java from the JDK version or if you have a newer JRE/JDK that will work as well.
which javac
will tell you the location, for example, /usr/bin/javac
. Just run directly using /usr/bin/java <program>
.
OR you can set the environment variable as a permanent solution.
You have used a higher version of the JDK to compile and trying to run from a lower version of JDK/JRE.
To check this, see the version information:
javac -version
java -version
They will be different and javac will have a higher version number.
To get around this, run using java from the JDK version or if you have a newer JRE/JDK that will work as well.
which javac
will tell you the location, for example, /usr/bin/javac
. Just run directly using /usr/bin/java <program>
.
OR you can set the environment variable as a permanent solution.
edited Nov 7 '14 at 14:25
Peter Mortensen
13.7k1986112
13.7k1986112
answered Sep 24 '14 at 1:27
L LawlietL Lawliet
1,13121127
1,13121127
add a comment |
add a comment |
Had this problem when I reverted to Java 6 and tried to run classes previously compiled with Java 7. What worked for me was Preferences > java > compiler --> set compliance level to 1.6 and crucially "configure project settings"..
add a comment |
Had this problem when I reverted to Java 6 and tried to run classes previously compiled with Java 7. What worked for me was Preferences > java > compiler --> set compliance level to 1.6 and crucially "configure project settings"..
add a comment |
Had this problem when I reverted to Java 6 and tried to run classes previously compiled with Java 7. What worked for me was Preferences > java > compiler --> set compliance level to 1.6 and crucially "configure project settings"..
Had this problem when I reverted to Java 6 and tried to run classes previously compiled with Java 7. What worked for me was Preferences > java > compiler --> set compliance level to 1.6 and crucially "configure project settings"..
answered Apr 15 '14 at 3:09
user3534268user3534268
6112
6112
add a comment |
add a comment |
Today, this error message appeared in our Tomcat 7 on Ubuntu 12.04.2 LTS (Precise Pangolin):
/var/log/tomcat7/localhost.2014-04-08.log:
Apr 8, 2014 9:00:55 AM org.apache.catalina.core.StandardContext filterStart
SEVERE: Exception starting filter struts2
java.lang.UnsupportedClassVersionError: controller/ReqAccept : Unsupported major.minor version 51.0 (unable to load class controller.ReqAccept)
The Struts application is compiled with Java 7.
It turned out, someone uses "service tomcat [stop/start]" to restart Tomcat 7,
$ ps -ef | grep java
tomcat7 31783 1 32 20:13 ? 00:00:03 /usr/lib/jvm/default-java/bin/java...
$ /usr/lib/jvm/default-java/bin/java -version
java version "1.6.0_27"
Which causes the "Unsupported major.minor version 51.0" error.
When we used "/etc/init.d/tomcat7 [stop/start]" to restart Tomcat 7, the problem was solved.
$ ps -ef | grep java
tomcat7 31886 1 80 20:24 ? 00:00:10 /usr/local/java/jdk1.7.0_15/bin/java
$ /usr/local/java/jdk1.7.0_15/bin/java -version
java version "1.7.0_15"
add a comment |
Today, this error message appeared in our Tomcat 7 on Ubuntu 12.04.2 LTS (Precise Pangolin):
/var/log/tomcat7/localhost.2014-04-08.log:
Apr 8, 2014 9:00:55 AM org.apache.catalina.core.StandardContext filterStart
SEVERE: Exception starting filter struts2
java.lang.UnsupportedClassVersionError: controller/ReqAccept : Unsupported major.minor version 51.0 (unable to load class controller.ReqAccept)
The Struts application is compiled with Java 7.
It turned out, someone uses "service tomcat [stop/start]" to restart Tomcat 7,
$ ps -ef | grep java
tomcat7 31783 1 32 20:13 ? 00:00:03 /usr/lib/jvm/default-java/bin/java...
$ /usr/lib/jvm/default-java/bin/java -version
java version "1.6.0_27"
Which causes the "Unsupported major.minor version 51.0" error.
When we used "/etc/init.d/tomcat7 [stop/start]" to restart Tomcat 7, the problem was solved.
$ ps -ef | grep java
tomcat7 31886 1 80 20:24 ? 00:00:10 /usr/local/java/jdk1.7.0_15/bin/java
$ /usr/local/java/jdk1.7.0_15/bin/java -version
java version "1.7.0_15"
add a comment |
Today, this error message appeared in our Tomcat 7 on Ubuntu 12.04.2 LTS (Precise Pangolin):
/var/log/tomcat7/localhost.2014-04-08.log:
Apr 8, 2014 9:00:55 AM org.apache.catalina.core.StandardContext filterStart
SEVERE: Exception starting filter struts2
java.lang.UnsupportedClassVersionError: controller/ReqAccept : Unsupported major.minor version 51.0 (unable to load class controller.ReqAccept)
The Struts application is compiled with Java 7.
It turned out, someone uses "service tomcat [stop/start]" to restart Tomcat 7,
$ ps -ef | grep java
tomcat7 31783 1 32 20:13 ? 00:00:03 /usr/lib/jvm/default-java/bin/java...
$ /usr/lib/jvm/default-java/bin/java -version
java version "1.6.0_27"
Which causes the "Unsupported major.minor version 51.0" error.
When we used "/etc/init.d/tomcat7 [stop/start]" to restart Tomcat 7, the problem was solved.
$ ps -ef | grep java
tomcat7 31886 1 80 20:24 ? 00:00:10 /usr/local/java/jdk1.7.0_15/bin/java
$ /usr/local/java/jdk1.7.0_15/bin/java -version
java version "1.7.0_15"
Today, this error message appeared in our Tomcat 7 on Ubuntu 12.04.2 LTS (Precise Pangolin):
/var/log/tomcat7/localhost.2014-04-08.log:
Apr 8, 2014 9:00:55 AM org.apache.catalina.core.StandardContext filterStart
SEVERE: Exception starting filter struts2
java.lang.UnsupportedClassVersionError: controller/ReqAccept : Unsupported major.minor version 51.0 (unable to load class controller.ReqAccept)
The Struts application is compiled with Java 7.
It turned out, someone uses "service tomcat [stop/start]" to restart Tomcat 7,
$ ps -ef | grep java
tomcat7 31783 1 32 20:13 ? 00:00:03 /usr/lib/jvm/default-java/bin/java...
$ /usr/lib/jvm/default-java/bin/java -version
java version "1.6.0_27"
Which causes the "Unsupported major.minor version 51.0" error.
When we used "/etc/init.d/tomcat7 [stop/start]" to restart Tomcat 7, the problem was solved.
$ ps -ef | grep java
tomcat7 31886 1 80 20:24 ? 00:00:10 /usr/local/java/jdk1.7.0_15/bin/java
$ /usr/local/java/jdk1.7.0_15/bin/java -version
java version "1.7.0_15"
edited Jul 12 '14 at 20:51
Peter Mortensen
13.7k1986112
13.7k1986112
answered Apr 8 '14 at 4:52
oraclesoonoraclesoon
641710
641710
add a comment |
add a comment |
I solved it. I ran:
JAVA_HOME=/usr/lib/jvm/java-7-openjdk-i386
The error is misleading, Unsupported major.minor version 51.0
. This gives the impression that version 51 (Java 7) is not supported. And we should use Java 6.
The error should have been:
The current Java version, 50, is unsupported. Use Java version 7 (51:0 and greater) instead.`
add a comment |
I solved it. I ran:
JAVA_HOME=/usr/lib/jvm/java-7-openjdk-i386
The error is misleading, Unsupported major.minor version 51.0
. This gives the impression that version 51 (Java 7) is not supported. And we should use Java 6.
The error should have been:
The current Java version, 50, is unsupported. Use Java version 7 (51:0 and greater) instead.`
add a comment |
I solved it. I ran:
JAVA_HOME=/usr/lib/jvm/java-7-openjdk-i386
The error is misleading, Unsupported major.minor version 51.0
. This gives the impression that version 51 (Java 7) is not supported. And we should use Java 6.
The error should have been:
The current Java version, 50, is unsupported. Use Java version 7 (51:0 and greater) instead.`
I solved it. I ran:
JAVA_HOME=/usr/lib/jvm/java-7-openjdk-i386
The error is misleading, Unsupported major.minor version 51.0
. This gives the impression that version 51 (Java 7) is not supported. And we should use Java 6.
The error should have been:
The current Java version, 50, is unsupported. Use Java version 7 (51:0 and greater) instead.`
edited Nov 7 '14 at 14:30
Peter Mortensen
13.7k1986112
13.7k1986112
answered Aug 22 '14 at 3:53
SiddharthSiddharth
6,523864110
6,523864110
add a comment |
add a comment |
Your Java file is compiled with a different version (higher compiler version) than the version (lower runtime version) you are trying to run it with.
It is basic understanding that classes compiled with lower versions are expected to run in the later higher versions. But the opposite (compiled with higher compiler version and trying to run it with lower runtime version) is quite not possible sometimes.
Hence you are shown this error, when trying to execute your program. Unsupported major.minor version x.x
Q: I have created an application in Java 7, but when my users try to
run it they get an Unsupported major.minor version 51.0 error. What
does this mean and what can I do about it?
A: If you compile an application using javac in Java 7, the resulting classfiles will have the 51.0 version number. Versions of
Java prior to 7 do not recognize this number, so your users will have
to upgrade to Java 7 prior to running your application. If you are not
using any Java 7 APIs you can try to compile your application using
javac -target 1.6 to create a 1.6-compatible classfile. If your
application is deployed using webstart you can specify the minimum
version required. For more information, see the docs on Java Web Start
and JNLP here. This issue will go away once we trigger autoupdate to
Java 7 for end-users currently having Java 6 on their desktops. The
timeline for this is not yet determined, we want to give developers
time to work out any issues between their code and JDK 7 first.
(Source: oracle.com.)
add a comment |
Your Java file is compiled with a different version (higher compiler version) than the version (lower runtime version) you are trying to run it with.
It is basic understanding that classes compiled with lower versions are expected to run in the later higher versions. But the opposite (compiled with higher compiler version and trying to run it with lower runtime version) is quite not possible sometimes.
Hence you are shown this error, when trying to execute your program. Unsupported major.minor version x.x
Q: I have created an application in Java 7, but when my users try to
run it they get an Unsupported major.minor version 51.0 error. What
does this mean and what can I do about it?
A: If you compile an application using javac in Java 7, the resulting classfiles will have the 51.0 version number. Versions of
Java prior to 7 do not recognize this number, so your users will have
to upgrade to Java 7 prior to running your application. If you are not
using any Java 7 APIs you can try to compile your application using
javac -target 1.6 to create a 1.6-compatible classfile. If your
application is deployed using webstart you can specify the minimum
version required. For more information, see the docs on Java Web Start
and JNLP here. This issue will go away once we trigger autoupdate to
Java 7 for end-users currently having Java 6 on their desktops. The
timeline for this is not yet determined, we want to give developers
time to work out any issues between their code and JDK 7 first.
(Source: oracle.com.)
add a comment |
Your Java file is compiled with a different version (higher compiler version) than the version (lower runtime version) you are trying to run it with.
It is basic understanding that classes compiled with lower versions are expected to run in the later higher versions. But the opposite (compiled with higher compiler version and trying to run it with lower runtime version) is quite not possible sometimes.
Hence you are shown this error, when trying to execute your program. Unsupported major.minor version x.x
Q: I have created an application in Java 7, but when my users try to
run it they get an Unsupported major.minor version 51.0 error. What
does this mean and what can I do about it?
A: If you compile an application using javac in Java 7, the resulting classfiles will have the 51.0 version number. Versions of
Java prior to 7 do not recognize this number, so your users will have
to upgrade to Java 7 prior to running your application. If you are not
using any Java 7 APIs you can try to compile your application using
javac -target 1.6 to create a 1.6-compatible classfile. If your
application is deployed using webstart you can specify the minimum
version required. For more information, see the docs on Java Web Start
and JNLP here. This issue will go away once we trigger autoupdate to
Java 7 for end-users currently having Java 6 on their desktops. The
timeline for this is not yet determined, we want to give developers
time to work out any issues between their code and JDK 7 first.
(Source: oracle.com.)
Your Java file is compiled with a different version (higher compiler version) than the version (lower runtime version) you are trying to run it with.
It is basic understanding that classes compiled with lower versions are expected to run in the later higher versions. But the opposite (compiled with higher compiler version and trying to run it with lower runtime version) is quite not possible sometimes.
Hence you are shown this error, when trying to execute your program. Unsupported major.minor version x.x
Q: I have created an application in Java 7, but when my users try to
run it they get an Unsupported major.minor version 51.0 error. What
does this mean and what can I do about it?
A: If you compile an application using javac in Java 7, the resulting classfiles will have the 51.0 version number. Versions of
Java prior to 7 do not recognize this number, so your users will have
to upgrade to Java 7 prior to running your application. If you are not
using any Java 7 APIs you can try to compile your application using
javac -target 1.6 to create a 1.6-compatible classfile. If your
application is deployed using webstart you can specify the minimum
version required. For more information, see the docs on Java Web Start
and JNLP here. This issue will go away once we trigger autoupdate to
Java 7 for end-users currently having Java 6 on their desktops. The
timeline for this is not yet determined, we want to give developers
time to work out any issues between their code and JDK 7 first.
(Source: oracle.com.)
edited May 25 '17 at 21:05
Peter Mortensen
13.7k1986112
13.7k1986112
answered Sep 13 '16 at 16:08
ManoharManohar
498914
498914
add a comment |
add a comment |
Oh Mac OS X I was able to solve this problem by setting the JAVA_HOME variable:
export JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk1.7.0_75.jdk/Contents/Home
add a comment |
Oh Mac OS X I was able to solve this problem by setting the JAVA_HOME variable:
export JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk1.7.0_75.jdk/Contents/Home
add a comment |
Oh Mac OS X I was able to solve this problem by setting the JAVA_HOME variable:
export JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk1.7.0_75.jdk/Contents/Home
Oh Mac OS X I was able to solve this problem by setting the JAVA_HOME variable:
export JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk1.7.0_75.jdk/Contents/Home
answered Apr 9 '15 at 9:10
TomTomTomTom
1,786158
1,786158
add a comment |
add a comment |
First let's get some basics right...
JRE is a component in NetBeans/Eclipse/standalone that is going to provide you with libraries, JVM, Java plugins & Java web start. Note that it does not provide compliers or debuggers.
JDK is the superset of JRE along with compliers and debuggers.
So when you have your default library as a JRE instead of JDK, you are going to have a nice time importing stuff, but it won't compile.
Instead, set your path to JDK (I use NetBeans, and I set them using netbeans.conf in netbeans/etc/netbeans.conf and change the path).
add a comment |
First let's get some basics right...
JRE is a component in NetBeans/Eclipse/standalone that is going to provide you with libraries, JVM, Java plugins & Java web start. Note that it does not provide compliers or debuggers.
JDK is the superset of JRE along with compliers and debuggers.
So when you have your default library as a JRE instead of JDK, you are going to have a nice time importing stuff, but it won't compile.
Instead, set your path to JDK (I use NetBeans, and I set them using netbeans.conf in netbeans/etc/netbeans.conf and change the path).
add a comment |
First let's get some basics right...
JRE is a component in NetBeans/Eclipse/standalone that is going to provide you with libraries, JVM, Java plugins & Java web start. Note that it does not provide compliers or debuggers.
JDK is the superset of JRE along with compliers and debuggers.
So when you have your default library as a JRE instead of JDK, you are going to have a nice time importing stuff, but it won't compile.
Instead, set your path to JDK (I use NetBeans, and I set them using netbeans.conf in netbeans/etc/netbeans.conf and change the path).
First let's get some basics right...
JRE is a component in NetBeans/Eclipse/standalone that is going to provide you with libraries, JVM, Java plugins & Java web start. Note that it does not provide compliers or debuggers.
JDK is the superset of JRE along with compliers and debuggers.
So when you have your default library as a JRE instead of JDK, you are going to have a nice time importing stuff, but it won't compile.
Instead, set your path to JDK (I use NetBeans, and I set them using netbeans.conf in netbeans/etc/netbeans.conf and change the path).
edited Jul 12 '14 at 20:46
Peter Mortensen
13.7k1986112
13.7k1986112
answered Mar 19 '14 at 17:49
Creative_CimmonsCreative_Cimmons
1441111
1441111
add a comment |
add a comment |
I had the problem whereby I was having to run a Maven compilation on my project from the command line in order to run my unit tests; if I made a change to the test class and let Eclipse automatically recompile it, then I got the "Unsupported major.minor version 51.0" error.
I do have both JDK6 and JDK7 installed, but all my JRE settings were pointing at 1.6, both in the pom and from the project properties page in Eclipse. No amount of Maven Update Project and/or refreshing solved this.
Finally I tried closing the project and re-opening it, and this seemed to fix it! HTH
add a comment |
I had the problem whereby I was having to run a Maven compilation on my project from the command line in order to run my unit tests; if I made a change to the test class and let Eclipse automatically recompile it, then I got the "Unsupported major.minor version 51.0" error.
I do have both JDK6 and JDK7 installed, but all my JRE settings were pointing at 1.6, both in the pom and from the project properties page in Eclipse. No amount of Maven Update Project and/or refreshing solved this.
Finally I tried closing the project and re-opening it, and this seemed to fix it! HTH
add a comment |
I had the problem whereby I was having to run a Maven compilation on my project from the command line in order to run my unit tests; if I made a change to the test class and let Eclipse automatically recompile it, then I got the "Unsupported major.minor version 51.0" error.
I do have both JDK6 and JDK7 installed, but all my JRE settings were pointing at 1.6, both in the pom and from the project properties page in Eclipse. No amount of Maven Update Project and/or refreshing solved this.
Finally I tried closing the project and re-opening it, and this seemed to fix it! HTH
I had the problem whereby I was having to run a Maven compilation on my project from the command line in order to run my unit tests; if I made a change to the test class and let Eclipse automatically recompile it, then I got the "Unsupported major.minor version 51.0" error.
I do have both JDK6 and JDK7 installed, but all my JRE settings were pointing at 1.6, both in the pom and from the project properties page in Eclipse. No amount of Maven Update Project and/or refreshing solved this.
Finally I tried closing the project and re-opening it, and this seemed to fix it! HTH
answered Jun 18 '14 at 16:29
Matthew WiseMatthew Wise
1,7421321
1,7421321
add a comment |
add a comment |
You have compiled your Java class with JDK 7 and you are trying to run same class on JDK 6 .
add a comment |
You have compiled your Java class with JDK 7 and you are trying to run same class on JDK 6 .
add a comment |
You have compiled your Java class with JDK 7 and you are trying to run same class on JDK 6 .
You have compiled your Java class with JDK 7 and you are trying to run same class on JDK 6 .
answered Jun 26 '14 at 7:40
Sagar VarpeSagar Varpe
1,72441939
1,72441939
add a comment |
add a comment |
- Install JDK 7.0.55 and set the Java for Eclipse for JDK 7.0.55.
- Build the project with JDK 7.0.55 by configuring on build path JDK 7.0.55.
- Set the compiler in Eclipse for JDK 7.0.55 by menu Windows -> Preferences -> Java -> Compiler - choose 1.7.
add a comment |
- Install JDK 7.0.55 and set the Java for Eclipse for JDK 7.0.55.
- Build the project with JDK 7.0.55 by configuring on build path JDK 7.0.55.
- Set the compiler in Eclipse for JDK 7.0.55 by menu Windows -> Preferences -> Java -> Compiler - choose 1.7.
add a comment |
- Install JDK 7.0.55 and set the Java for Eclipse for JDK 7.0.55.
- Build the project with JDK 7.0.55 by configuring on build path JDK 7.0.55.
- Set the compiler in Eclipse for JDK 7.0.55 by menu Windows -> Preferences -> Java -> Compiler - choose 1.7.
- Install JDK 7.0.55 and set the Java for Eclipse for JDK 7.0.55.
- Build the project with JDK 7.0.55 by configuring on build path JDK 7.0.55.
- Set the compiler in Eclipse for JDK 7.0.55 by menu Windows -> Preferences -> Java -> Compiler - choose 1.7.
edited Nov 7 '14 at 14:31
Peter Mortensen
13.7k1986112
13.7k1986112
answered Aug 4 '14 at 10:21
siddmuk2005siddmuk2005
916
916
add a comment |
add a comment |
In my case the problem was in the server runtime configuration:
Check the JRE is the version you need:
The project was in version 1.7 and the server JRE was set as 1.6, after changing to the proper java version it launched fine.
add a comment |
In my case the problem was in the server runtime configuration:
Check the JRE is the version you need:
The project was in version 1.7 and the server JRE was set as 1.6, after changing to the proper java version it launched fine.
add a comment |
In my case the problem was in the server runtime configuration:
Check the JRE is the version you need:
The project was in version 1.7 and the server JRE was set as 1.6, after changing to the proper java version it launched fine.
In my case the problem was in the server runtime configuration:
Check the JRE is the version you need:
The project was in version 1.7 and the server JRE was set as 1.6, after changing to the proper java version it launched fine.
answered Mar 6 '18 at 12:29
Mike-BellMike-Bell
6001722
6001722
add a comment |
add a comment |
1 2
next
protected by bummi Sep 22 '14 at 16:30
Thank you for your interest in this question.
Because it has attracted low-quality or spam answers that had to be removed, posting an answer now requires 10 reputation on this site (the association bonus does not count).
Would you like to answer one of these unanswered questions instead?
did you install jdk as well ? jre is Java RunTime environment , To create java apps , you need jdk as well
– CyprUS
Apr 30 '12 at 11:30
yes i did, and now my path variable points to where jdk is. yet i still have this "unsupported minor version 51.0" error do you think i should install older version of jdk? i m using jdk 1.7.0
– ERJAN
May 1 '12 at 8:30
20
This happened to me on Mac OS X when I was having problems due to the weird Apple java 6 and Oracle java 7 situation on OSX these days. short version: Compile with JDK7, Run with JDK6, get this.
– Warren P
Oct 7 '13 at 4:00
6
In java ClassName should Be Start with Capital letter ;)
– Ashish Panery
Feb 3 '14 at 16:47
5
For El Captain, this answer fixed it for me: stackoverflow.com/a/34201991/1615594
– tsuz
Jan 24 '16 at 11:35