为什么Spring DispatcherServlet找不到我的控制器方法?

时间:2016-04-28 13:50:30

标签: java spring web-services spring-mvc tomcat

我们说我有以下Spring控制器:

@Controller
public class FooController
{
    @RequestMapping(value = "/foo", method = RequestMethod.GET, headers = { "Content-Type=text/plain" })
    @ResponseBody
    public String foo(String bar)
    {
        return "Bar is " + bar;
    }
}

这是关联的web.xml文件:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
     xmlns="http://java.sun.com/xml/ns/javaee"
     xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
     xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
     id="WebApp_ID"
     version="2.5">
  <display-name>Foo</display-name>
  <servlet>
    <servlet-name>FooServlet</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <init-param>
      <param-name>contextConfigLocation</param-name>
      <param-value>/WEB-INF/servlet.xml</param-value>
    </init-param>
    <load-on-startup>0</load-on-startup>
  </servlet>
  <servlet-mapping>
    <servlet-name>FooServlet</servlet-name>
    <url-pattern>/</url-pattern>
  </servlet-mapping>
  <welcome-file-list>
    <welcome-file>index.html</welcome-file>
  </welcome-file-list>
</web-app>

这里是关联的servlet.xml文件:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:mvc="http://www.springframework.org/schema/mvc"
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd">
  <mvc:annotation-driven/>
  <bean id="FooController" class="foo.FooController"/>
</beans>

仅供参考,我使用的是Spring Framework 3.0.5版。我知道这是一个旧版本,但它是我必须工作的约束。

因此,我将上面构建的WAR文件(例如FooApp.war)部署到Tomcat(版本7.0.67)。一切都很好。但是当我导航到http://localhost:8080/FooApp/foo?bar=baz时,我在浏览器中收到404错误,而Tomcat控制台中出现以下错误:

Apr 28, 2016 9:43:33 AM org.springframework.web.servlet.mvc.support.DefaultHandlerExceptionResolver handleNoSuchRequestHandlingMethod
WARNING: No matching handler method found for servlet request: path '/foo', method 'GET', parameters map['bar' -> array<String>['baz']]

所以我的问题是,我的配置错误导致了这个问题?我确定它是什么,但我很难搞清楚它是什么。

修改:根据M. Deinum的评论删除了SimpleUrlHandlerMapping

2 个答案:

答案 0 :(得分:0)

我从here下载了示例项目,并开始查看它与我的测试项目之间的区别。我最终将其缩小到我的控制器方法中headers = { "Content-Type=text/plain" }注释中@RequestMapping的存在。删除后,一切正常。

答案 1 :(得分:-1)

将“context:component-scan base-package =”包名“/”添加到servlet.xml。这样可以自动扫描控制器。