Spring mvc Spring MVC控制器不返回值

Spring mvc Spring MVC控制器不返回值,spring-mvc,Spring Mvc,我是spring mvc的新手。我正在尝试从helloworld.jsp上的模型视图控制器获取响应。当我运行应用程序时,我只得到页面上定义的${message}${name}。我在控制器文件中使用了sysout,但在控制台上也没有得到任何东西。请你检查一下我遗漏了什么 spring mvc版本:4.2.6.0版本 index.jsp <%@ page language="java" contentType="text/html; charset=ISO-8859-1"

我是spring mvc的新手。我正在尝试从helloworld.jsp上的模型视图控制器获取响应。当我运行应用程序时,我只得到页面上定义的${message}${name}。我在控制器文件中使用了sysout,但在控制台上也没有得到任何东西。请你检查一下我遗漏了什么

spring mvc版本:4.2.6.0版本

index.jsp

        <%@ page language="java" contentType="text/html; charset=ISO-8859-1"
        pageEncoding="ISO-8859-1"%>
        <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
        <html>
        <head>
        <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
        <title>Spring 4 MVC - HelloWorld Index Page</title>
        </head>
        <body>

            <center>
                <h2>Hello World</h2>
                <h3>
                    <a href="helloworld.jsp">Click Here</a>
                </h3>
            </center>
        </body>
        </html>
<html>
<head>
<title>Spring 4 MVC -HelloWorld</title>
</head>
<body>
        <h2>${message} ${name}</h2>


</body>
</html>
应用程序结构

日志:

INFO: Initializing Spring FrameworkServlet 'spring-dispatcher'
Jun 13, 2016 9:30:23 AM org.springframework.web.servlet.DispatcherServlet initServletBean
INFO: FrameworkServlet 'spring-dispatcher': initialization started
Jun 13, 2016 9:30:23 AM org.springframework.web.context.support.XmlWebApplicationContext prepareRefresh
INFO: Refreshing WebApplicationContext for namespace 'spring-dispatcher-servlet': startup date [Mon Jun 13 09:30:23 BST 2016]; root of context hierarchy
Jun 13, 2016 9:30:23 AM org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
INFO: Loading XML bean definitions from ServletContext resource [/WEB-INF/spring-dispatcher-servlet.xml]
Jun 13, 2016 9:30:24 AM org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter initControllerAdviceCache
INFO: Looking for @ControllerAdvice: WebApplicationContext for namespace 'spring-dispatcher-servlet': startup date [Mon Jun 13 09:30:23 BST 2016]; root of context hierarchy
Jun 13, 2016 9:30:24 AM org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter initControllerAdviceCache
INFO: Looking for @ControllerAdvice: WebApplicationContext for namespace 'spring-dispatcher-servlet': startup date [Mon Jun 13 09:30:23 BST 2016]; root of context hierarchy
Jun 13, 2016 9:30:24 AM org.springframework.web.servlet.DispatcherServlet initServletBean
INFO: FrameworkServlet 'spring-dispatcher': initialization completed in 1211 ms
Jun 13, 2016 9:30:24 AM org.springframework.web.servlet.PageNotFound noHandlerFound
WARNING: No mapping found for HTTP request with URI [/TestApp/index] in DispatcherServlet with name 'spring-dispatcher'

这应该是更新后的index.jsp。此外,我们将链接作为索引,因为您的请求映射仅为/index

 <%@ page language="java" contentType="text/html; charset=ISO-8859-1"
        pageEncoding="ISO-8859-1"%>
        <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
        <html>
        <head>
        <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
        <title>Spring 4 MVC - HelloWorld Index Page</title>
        </head>
        <body>

            <center>
                <h2>Hello World</h2>
                <h3>
                    <a href="index">Click Here</a>
                </h3>
            </center>
        </body>
        </html>
如果不存在,则表示未完成请求映射。请参阅下面更新的web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app id="WebApp_ID" version="3.0"
         xmlns="http://java.sun.com/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
         http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">

    <display-name>FirstSpringMVCProject</display-name>

    <servlet>
        <servlet-name>spring-dispatcher</servlet-name>
        <servlet-class>
            org.springframework.web.servlet.DispatcherServlet
        </servlet-class>
        <load-on-startup>1</load-on-startup>
    </servlet>

    <servlet-mapping>
        <servlet-name>spring-dispatcher</servlet-name>
        <url-pattern>/</url-pattern>
    </servlet-mapping>

</web-app>
要解决此问题,请将helloworld.jsp放入WEB-INF中

更新为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>com.stackoverflow</groupId>
    <artifactId>spring-mvc-check</artifactId>
    <packaging>war</packaging>
    <version>1.0-SNAPSHOT</version>
    <dependencies>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
            <version>4.2.6.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context-support</artifactId>
            <version>4.2.6.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
            <version>2.6.2</version>
        </dependency>
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>javax.servlet-api</artifactId>
            <version>3.1.0</version>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>org.mortbay.jetty</groupId>
            <artifactId>jsp-api-2.0</artifactId>
            <version>6.1.26</version>
            <scope>provided</scope>
        </dependency>
    </dependencies>
    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.tomcat.maven</groupId>
                <artifactId>tomcat7-maven-plugin</artifactId>
                <version>2.2</version>
            </plugin>
        </plugins>
    </build>
</project>

4.0.0
com.stackoverflow
弹簧mvc检查
战争
1.0-快照
org.springframework
SpringWebMVC
4.2.6.1发布
org.springframework
spring上下文支持
4.2.6.1发布
com.fasterxml.jackson.core
杰克逊数据绑定
2.6.2
javax.servlet
javax.servlet-api
3.1.0
假如
org.mortbay.jetty
jsp-api-2.0
6.1.26
假如
org.apache.tomcat.maven
tomcat7 maven插件
2.2

尝试将以下内容添加到spring dispatcher servlet下的web.xml中

<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath:spring-dispatcher-servlet.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
org.springframework.web.servlet.DispatcherServlet
上下文配置位置
类路径:spring-dispatcher-servlet.xml
1.

使用maven创建spring mvc项目似乎存在一些问题。由于某些原因,它不会生成.class文件。我尝试了各种选择,但没有一个对我有效

然后我创建了一个简单的动态web项目,它工作得很好

我仍然想知道为什么maven没有工作


谢谢你的帮助

您可以使用默认的弹簧(sts)设置,设置中没有问题

首先,您不需要使用index.jsp。 只需使用helloworld.jsp

(控制员)

在浏览器中输入url(您可以使用localhost/context path/show/message)。 您可以成功地显示消息

如果您想使用index.jsp (您可以使用index.jsp)


默认情况下,EL处于禁用状态



您的链接应该是
/index
而不是jsp。另外,如果你可以使用你的
index.jsp
中的链接,你的jsp不是你告诉spring的地方。Deinum,对不起,我没听清楚。你能告诉我该换什么/在哪里吗?我说了什么。将文件中的链接更改为
/index
…哪个文件?helloworld.jsp,index.jsp??您在
hello world.jsp
中有链接吗?获取此错误-------------------2016年6月10日下午4:08:16 org.springframework.web.servlet.PageNotFound noHandlerFound警告:未找到URI为[/TestApp/index]的HTTP请求的映射在名为“spring-dispatcher”的DispatcherServlet中,可以粘贴应用程序启动日志吗?您已经尝试了/index,现在也尝试了/TestApp/index。你在启动时看到/index映射了吗?我说的是这个日志
INFO:Mapped“{[/index]}”到public org.springframework.web.servlet.ModelAndView com.test.testcontroller.testcontroller.showMessage()
现在您的jsp helloworld不在WEB-INF中,而viewResolver中的映射是用于WEB-INF的。因此,您应该获得类似于HTTP Status 404-/TestApp/WEB-INF/helloworld.jsp的内容,将其放入WEB-INF中,它应该可以解决问题。我没有在日志文件中获得该条目。我已经按照您的建议更改了web.xml,但仍然不确定您到底缺少了什么。我也用pom.xml更新了答案。请复制并尝试。我想这是现在剩下的唯一一个文件了。我尝试添加这个标签,但是得到了错误----cvc复杂类型。2.4.a:发现了以元素“init-param”开头的无效内容。你能发布整个web.xml和servlet.xml吗?
INFO: Mapped "{[/index]}" onto public org.springframework.web.servlet.ModelAndView com.test.testcontroller.TestController.showMessage()
<?xml version="1.0" encoding="UTF-8"?>
<web-app id="WebApp_ID" version="3.0"
         xmlns="http://java.sun.com/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
         http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">

    <display-name>FirstSpringMVCProject</display-name>

    <servlet>
        <servlet-name>spring-dispatcher</servlet-name>
        <servlet-class>
            org.springframework.web.servlet.DispatcherServlet
        </servlet-class>
        <load-on-startup>1</load-on-startup>
    </servlet>

    <servlet-mapping>
        <servlet-name>spring-dispatcher</servlet-name>
        <url-pattern>/</url-pattern>
    </servlet-mapping>

</web-app>
HTTP Status 404 - /spring-mvc-check/WEB-INF/helloworld.jsp
<?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>com.stackoverflow</groupId>
    <artifactId>spring-mvc-check</artifactId>
    <packaging>war</packaging>
    <version>1.0-SNAPSHOT</version>
    <dependencies>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
            <version>4.2.6.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context-support</artifactId>
            <version>4.2.6.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
            <version>2.6.2</version>
        </dependency>
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>javax.servlet-api</artifactId>
            <version>3.1.0</version>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>org.mortbay.jetty</groupId>
            <artifactId>jsp-api-2.0</artifactId>
            <version>6.1.26</version>
            <scope>provided</scope>
        </dependency>
    </dependencies>
    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.tomcat.maven</groupId>
                <artifactId>tomcat7-maven-plugin</artifactId>
                <version>2.2</version>
            </plugin>
        </plugins>
    </build>
</project>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath:spring-dispatcher-servlet.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
package com.test.testcontroller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView;

@Controller
public class TestController {

    @RequestMapping(value = "/show/message")
    public ModelAndView showMessage(ModelAndView mv) {
        System.out.println("in controller");

        mv.addObject("message", "this is a message for");
        mv.addObject("name", "Spring");
        mv.setViewName("/helloworld");

        return mv;
    }

}
  <%@ page language="java" contentType="text/html; charset=ISO-8859-1"
    pageEncoding="ISO-8859-1"%>
    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
    <title>Spring 4 MVC - HelloWorld Index Page</title>
    </head>
    <body>

        <center>
            <h2>Hello World</h2>
            <h3>
                <a href="/show/message">Click Here</a>
            </h3>
        </center>
    </body>
    </html>
@Controller
public class TestController {

....

    @RequestMapping(value = "/index")
    public String showIndex() {

        return "/index";
    }

}
<%@ page isELIgnored="false" %>