Issue
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 )
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
Answered By - Kyan