【问题标题】:Spring MVC controllers not loadedSpring MVC 控制器未加载
【发布时间】:2015-11-30 08:58:37
【问题描述】:

我遇到了 Spring 没有拿起控制器的问题。我使用 maven webapp 原型在 Eclipse 中创建了一个项目,它运行良好——我可以访问 index.jsp 页面。当我将 Spring 添加到项目中时,问题就开始了。 (上下文、控制器等)

我正在使用 Eclipse Mars、Tomcat 8、maven 3.3.3 和 Spring 4.2.2

这是我在日志中看到的(可能只有第三行很重要):

Looking for matching resources in directory tree [C:\Users\dima\spring_workspace\.metadata\.plugins\org.eclipse.wst.server.core\tmp1\wtpwebapps\cte\WEB-INF\classes\com\company\dept\demo\cte\controller]
Searching directory [C:\Users\dima\spring_workspace\.metadata\.plugins\org.eclipse.wst.server.core\tmp1\wtpwebapps\cte\WEB-INF\classes\com\company\dept\demo\cte\controller] for files matching pattern [C:/Users/dima/spring_workspace/.metadata/.plugins/org.eclipse.wst.server.core/tmp1/wtpwebapps/cte/WEB-INF/classes/com/company/dept/demo/cte/controller/**/*.class]
Resolved location pattern [classpath*:com/company/dept/demo/cte/controller/**/*.class] to resources []

而不是像

INFO: Mapped URL path ...

因此,我在尝试打开网页时收到 404。这些是文件:

调度程序-servlet.xml

<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:mvc="http://www.springframework.org/schema/mvc" 
    xmlns:context="http://www.springframework.org/schema/context"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:ldap="http://www.springframework.org/schema/ldap"
    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
        http://www.springframework.org/schema/context 
        http://www.springframework.org/schema/context/spring-context.xsd
        http://www.springframework.org/schema/ldap 
        http://www.springframework.org/schema/ldap/spring-ldap.xsd">

    <context:component-scan base-package="com.company.dept.demo.cte.controller" />

    <mvc:annotation-driven/>

    <bean id="viewResolver"
        class="org.springframework.web.servlet.view.UrlBasedViewResolver">
        <property name="viewClass"
            value="org.springframework.web.servlet.view.JstlView" />
        <property name="prefix" value="/WEB-INF/jsp/" />
        <property name="suffix" value=".jsp" />
    </bean>
</beans>

web.xml

<!DOCTYPE web-app PUBLIC
 "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
 "http://java.sun.com/dtd/web-app_2_3.dtd" >

<web-app>
    <display-name>Archetype Created Web Application</display-name>

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

    </servlet>

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

</web-app>

这是我的控制器:

package com.company.dept.demo.cte.controller;

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

@Controller
@RequestMapping("/pid")
public class PidController {

    @RequestMapping(value="/hello")
    public ModelAndView helloWorld() {
        ModelAndView mav = new ModelAndView("pidHello");
        mav.addObject("message", "hello world");
        return mav;
    }
}

当尝试访问 localhost:8080/cte/pid/hello 404 返回并且日志显示:

DispatcherServlet with name 'dispatcher' processing GET request for [/cte/pid/hello]
Looking up handler method for path /pid/hello
Did not find handler method for [/pid/hello]
No mapping found for HTTP request with URI [/cte/pid/hello] in DispatcherServlet with name 'dispatcher'

谢谢。

更新: WAR 文件是正确的,但由于某种原因,当它部署到 Tomcat 控制器类时没有被复制。

【问题讨论】:

  • 对于初学者来说,改进您的 web.xml 目前您声明它是一个 Servlet Spec 2.3 应用程序,而您可能至少需要 3.0(请参阅here 了解 sn-p)。接下来,您似乎将其部署在 Eclipse 内部/从 Eclipse 尝试清理和重新部署项目。您还声明您正在使用 maven,您是否导入了一个 maven 项目或创建了一个 web 项目然后添加了 maven?
  • 返回 404 错误的url 是什么?
  • 你的基础包是控制器吗?我可以在您的 dispatcherServlet.xml 中看到这一点。去一个包后面并为它的控制器添加一个排除过滤器。类似于:pastebin.com/ahrw0jVD
  • 我经常遇到这种情况。清理项目并重启tomcat经常会加载Controllers中定义的映射。
  • 你确定你的控制器没有被调用吗?还是找不到JSP?另外,您的控制器位于哪个目录中,您确定在将其部署到服务器时已将其导出?

标签: java eclipse spring maven spring-mvc


【解决方案1】:

它是你的完整 web.xml,因为你必须将你的调度程序 servlet 引用添加到 web.xml,如下所示 -

    <servlet>
    <servlet-name>dispatcher</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <init-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>/WEB-INF/dispatcher-servlet.xml</param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
</servlet>

【讨论】:

  • 没有帮助。日志看起来基本相同。 “已解决位置模式 [classpath*:com/company/dept/demo/cte/controller/**/*.class] 到资源 []”
  • 这基本上是显式配置默认值,无助于解决问题。
猜你喜欢
  • 1970-01-01
  • 2020-01-16
  • 2013-04-23
  • 1970-01-01
  • 2017-01-31
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多