20
votes

I've been working with a co-worker on a problem I have been experiencing on a new project I just joined. Long story short, maven isn't building my .war file correctly. When I give my co-worker my war file, he experiences the same problem I have, and when he gives me his compiled .war file, everything works. We are both working with the same source. So, I am trying to get maven setup correctly (the same as his), we both have the same version of maven now. However, I think maven is looking at the java_home incorrectly.

when I do an mvn -version command, I get the following:

C:\java\KME_workspace\CU-KME>mvn -version
Apache Maven 3.0.4 (r1232337; 2012-01-17 03:44:56-0500)
Maven home: C:\java\tools\apache-maven-3.0.4
Java version: 1.6.0_45, vendor: Sun Microsystems Inc.
Java home: C:\java\jdks\jdk1.6.0_45\jre
Default locale: en_US, platform encoding: Cp1252
OS name: "windows 7", version: "6.1", arch: "amd64", family: "windows"

My system's JAVA_HOME variable is set correctly to C:\java\jdks\jdk1.6.0_45.

Anyone know my maven is looking at the jre, and how do I set it correctly back to the JDK? It's possible I am looking at the problem in correctly too, so if you have any ideas, that would be great.

Thanks.


As some noted, the JRE reference in the java home in the maven version was a red herring rabbit hole on my part. Upon further testing I have some new interesting information. I am running maven commands directly from the command line. I check out code from our svn repository with eclipse, and try to run a maven package on that code, and the .war doesn't build correctly. However, if I do a team export in eclipse to a new directory, and the run the maven package on that, it builds the .war fine and works perfectly. As I understand it, the team export in eclipse removes all the subversion files in the exported directory. Anyone have any ideas on how to solve this?

7
What is incorrect about your WAR file? Perhaps that will give us some hints. Also, just so you know running mvn --version on my Windows 7 box gives me the same output (except with Java 7) and my war files build fine. - thatidiotguy
I don't think maven is the source of your problem. Running mvn -version on my Linux box shows Java home as /usr/local/java/7u25/jre. What do you mean by "maven isn't building my war file correctly". Have you compared the two war files to see what's different? - Vivin Paliath
Maven (mvn) is a shell script; it's just telling you what jre it's using to actually do stuff. The output you post is exactly what it should be. - Brian Roach
Maven is correct -- it's using the jdk, as you can see from jdk1.6.0_45. What is the actual problem you are observing with your build? - Tom G
also, you should add what does ".war doesn't build correctly" actually mean, preferrably with a test case. It's really hard to have an answer without it. - eis

7 Answers

25
votes

From the Maven Properties Guide:

${java.home} specifies the path to the current JRE_HOME environment use with relative paths to get for example: ${java.home}../bin/java.exe

java.home property is not the same thing as JAVA_HOME environment setting. It is actually dynamic property showing you which JRE is running your code. 

Try setting the java.home property correctly and see if it works.

3
votes

In Eclipse, Window>Preferences>Java>Installed JREs> make sure jdk is present and selected.

If jdk and jre both are present, then delete jre from Installed JREs.

3
votes

You can replace the environment from jre to jdk in Eclipse IDE as follows if it also shows compiler unavailable :

  • (right-click) your_project_name > Build Path > Configure Build Path > Libraries > (double-click) JRE System Libraries > Alternate Jre : jdk 1.8 >ok
  • Then from Installed JRES option in Libraries select jdk 1.8
  • Project > Clean
  • Maven > Update
0
votes

Windows CMD don't refresh environment variables and you need run new instance for applying new environment setting and refresh new variable JAVA_HOME.

0
votes

Once you have the JDK installation path:

  1. Right-click the My Computer icon on your desktop and select Properties.
  2. Click the Advanced tab.
  3. Click the Environment Variables button.
  4. Under System Variables, click New.
  5. Enter the variable name as JAVA_HOME.
  6. Enter the variable value (one of the paths mentioned above) as the installation path for the Java Development Kit.
  7. Click OK.
  8. Click Apply Changes.

You might need to restart windows.

This worked for me.

0
votes

You can modify it on this window:

enter image description here

0
votes

This error also occurs, if you have variable named as javapath. Try to delete it, if you've already specified e.g. like JAVA_HOME -> "C:\Program Files\Java\jdk1.8.0_171" and then in Path -> "%JAVA_HOME%\bin"