Search code examples
springspring-mvcweb.xmlspring-annotationstomcat9

Spring MVC sub mapping @RequestMapping throws 404


BE GENEROUS AND TELL US WHY I AM HAVING THIS SILLY ISSUE

Everything works fine with no mapping! but I have a simple issue. I have set a parent mapping @ "/hello" and sub-mapped a method @ "/showForm", Dispatcher is set to "/" but I get 404 (see code fig. 3). I couldn't find an answer to an issue SIMILAR to mine.

See code below & TAGS for my setup

Controller fig.1

   @Controller
    @RequestMapping("/hello")
    public class HelloWorldController {



        @RequestMapping("/showForm")
        public String showForm() {
            return "hello-world";
        }

web.xml fig.2

<servlet>
    <servlet-name>yktech</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
</servlet>

<servlet-mapping>
    <servlet-name>yktech</servlet-name>
    <url-pattern>/</url-pattern>
</servlet-mapping>

Tomcat Error fig.3

Type Status Report

Message /yktech/hello/WEB-INF/view/hello-world.jsp

Description The origin server did not find a current representation for the target resource or is not willing to disclose that one exists.

EDIT: FORGOT THE BEAN FIG. 4

<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="WEB-INF/view/"/>
<property name="suffix" value=".jsp"/>
</bean>

EDIT: STRUCTURE TREE ( MESSY I KNOW )

enter image description here

edit 4 , index.jsp

<html>
<body>
<h2>Welcome to my homepage
</h2>
<a href="hello/showForm">Show form</a>

<a href="Student/showForm">Show STUDENT form</a>
</body>
</html>

edit 5 pom.xml

<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/maven-v4_0_0.xsd">

  <modelVersion>4.0.0</modelVersion>
  <groupId>com.yktech</groupId>
  <artifactId>yktech</artifactId>
  <packaging>war</packaging>
  <version>1.0</version>
  <name>yktech</name>
  <url>http://maven.apache.org</url>


  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>3.8.1</version>
      <scope>test</scope>
    </dependency>

    <!-- https://mvnrepository.com/artifact/org.springframework/spring-webmvc -->
<dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-webmvc</artifactId>
    <version>4.3.17.RELEASE</version>
</dependency>

 <dependency>
        <groupId>commons-logging</groupId>
        <artifactId>commons-logging</artifactId>
        <version>1.2</version>
     </dependency>    
  </dependencies>
  <build>
    <finalName>yktech</finalName>
  </build>
</project>

EDIT 6 , SERVER LOG , MAPPING URLS

INFO: Loading XML bean definitions from ServletContext resource [/WEB-INF/yktech-servlet.xml]
Jul 30, 2018 10:19:30 PM org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping registerHandler
INFO: Mapped URL path [/hello/processForm] onto handler 'helloWorldController'
Jul 30, 2018 10:19:30 PM org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping registerHandler
INFO: Mapped URL path [/hello/processForm.*] onto handler 'helloWorldController'
Jul 30, 2018 10:19:30 PM org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping registerHandler
INFO: Mapped URL path [/hello/processForm/] onto handler 'helloWorldController'
Jul 30, 2018 10:19:30 PM org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping registerHandler
INFO: Mapped URL path [/hello/processFormVersionTwo] onto handler 'helloWorldController'
Jul 30, 2018 10:19:30 PM org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping registerHandler
INFO: Mapped URL path [/hello/processFormVersionTwo.*] onto handler 'helloWorldController'
Jul 30, 2018 10:19:30 PM org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping registerHandler
INFO: Mapped URL path [/hello/processFormVersionTwo/] onto handler 'helloWorldController'
Jul 30, 2018 10:19:30 PM org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping registerHandler
INFO: Mapped URL path [/hello/showForm] onto handler 'helloWorldController'
Jul 30, 2018 10:19:30 PM org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping registerHandler
INFO: Mapped URL path [/hello/showForm.*] onto handler 'helloWorldController'
Jul 30, 2018 10:19:30 PM org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping 

registerHandler
    INFO: Mapped URL path [/hello/showForm/] onto handler 'helloWorldController'

... CARRIES ON SHOWS NO ERRORS....

Solution

  • Issue is in the view resolver bean, the prefix does not have a "/" in the beginning causing Spring to call any parented mapping requests from root rather than from /WEB-INF/view