Issue
I have a very basic Spring MVC REST application which when deployed on Tomcat and called in browser or Postman with http://localhost:8080
, should display hello but instead it shows Tomcat Welcome page. Anyone is able to tell me what did I miss or whether there is someting wrong with deployment (I have done this through InteliJ as well as by dropping war into tomcat directly)? I have tried making multiple changes but none seems to work so any tip would be helpful.
NOTE: My sample app is very similar to this one https://gist.github.com/joshlong/6431608
My Code:
Config.java
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.EnableWebMvc;
import org.springframework.web.servlet.support.AbstractAnnotationConfigDispatcherServletInitializer;
@Configuration
@ComponentScan("app")
@EnableWebMvc
public class Config extends AbstractAnnotationConfigDispatcherServletInitializer {
@Override
protected Class<?>[] getRootConfigClasses() {
return new Class[0];
}
@Override
protected Class<?>[] getServletConfigClasses() {
return new Class[] {Config.class};
}
@Override
protected String[] getServletMappings() {
return new String[] {"/"};
}
}
Hello.java
package app;
import org.springframework.http.MediaType;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class Hello {
@GetMapping
public String main() {
return "Hello";
}
}
pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>pl.bykowski</groupId>
<artifactId>electronic-apps</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>war</packaging>
<properties>
<maven.compiler.source>17</maven.compiler.source>
<maven.compiler.target>17</maven.compiler.target>
</properties>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.13.2</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.3.22</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>4.0.1</version>
</dependency>
</dependencies>
<build>
<finalName>electronic-apps</finalName>
<pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) -->
<plugins>
<plugin>
<artifactId>maven-clean-plugin</artifactId>
<version>3.2.0</version>
</plugin>
<!-- see http://maven.apache.org/ref/current/maven-core/default-bindings.html#Plugin_bindings_for_war_packaging -->
<plugin>
<artifactId>maven-resources-plugin</artifactId>
<version>3.3.0</version>
</plugin>
<plugin>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.10.1</version>
</plugin>
<plugin>
<artifactId>maven-surefire-plugin</artifactId>
<version>3.0.0-M7</version>
</plugin>
<plugin>
<artifactId>maven-war-plugin</artifactId>
<version>3.3.2</version>
</plugin>
<plugin>
<artifactId>maven-install-plugin</artifactId>
<version>3.0.1</version>
</plugin>
<plugin>
<artifactId>maven-deploy-plugin</artifactId>
<version>3.0.0</version>
</plugin>
</plugins>
</pluginManagement>
</build>
</project>
Project Structure:
Result:
EDIT:
I have checked it in the manager on different Tomcat and the application is there but still it doesn't work whether I call it http://localhost:8080/electronic-apps/
or http://localhost:8080/
Solution
You must include the context path in the URL when you call it.
In your case it would be:
http://localhost:8125/electronic-apps/
When you do this, you will see Hello
in the browser, assuming the .war
file was deployed correctly.
BTW: You can check the deployment in Tomcat. Prerequisite is that in the file tomcat-users.xml
the admin user is configured/uncommented.
Just call:
http://localhost:8125/manager/html
A list of configured applications appears. It should also include /electronic-apps
. The UI also offers a possibility to deploy a WAR file if you scroll down. However, it would also work if you simply copy the electronic-apps.war
file into Tomcat's webapps
folder.
Problem 2
The second problem of the updated question has a different cause. Here the OP uses a Tomcat 10 instance (as you can see in the screenshot).
Applications that run on Tomcat 9 and earlier will not run on Tomcat 10 without changes. Java EE based applications designed for Tomcat 9 and earlier may be placed in the $CATALINA_BASE/webapps-javaee directory and Tomcat will automatically convert them to Jakarta EE and copy them to the webapps directory. This conversion is performed using the Apache Tomcat migration tool for Jakarta EE tool which is also available as a separate download for off-line use.
The mentioned migration tool can be downloaded from here: https://tomcat.apache.org/download-migration.cgi
And indeed, a quick test shows that applying this tool works as expected. Without applying this tool, the error appears as shown in your Tomcat 10 screenshot.
So in your case:
- create the
electronic-apps.war
- use this in your Tomcat 9 installation
- apply the migration tool and create a new
electronic-apps.war
- this migrated .war file can then be used with your Tomcat 10 installation
For Tomcat 10, you also need to add the context path to the URL (i.e. http://localhost:8080/electronic-apps/) for the app to run.
Answered By - Stephan Schlecht
Answer Checked By - Marilyn (JavaFixing Volunteer)