Spring Boot MVC应用程序在部署到外部Tomcat / tc Server实例时返回HTTP 404

时间:2015-06-07 23:43:43

标签: java spring spring-mvc tomcat servlet-3.0

我正在使用Spring Boot和Spring web starter开发一个简单的应用程序。当我使用嵌入式Tomcat服务器(JAR打包)进行测试时,它非常顺利。我需要调试一些东西,所以我认为最好将它作为WAR部署在外部Tomcat服务器上(或者实际上是STS上捆绑的外部Pivotal tc服务器)。

我遵循了Spring Boot's Documentation中所述的程序,在运行应用程序时,我可以看到加载我的控制器,请求等的日志(是吗?Nay。)。一旦容器启动,任何请求都会导致丑陋的404。

我知道Spring Boot会生成符合Servlet 3的容器,因此不应严格要求web.xml文件。我所要做的就是将我的应用程序的入口点指向一个扩展SpringBootServletInitializer的类。这是:

package com.company.ci.integration;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.builder.SpringApplicationBuilder;
import org.springframework.boot.context.web.SpringBootServletInitializer;

@SpringBootApplication
public class GitlabWebhookProcessingApplication extends
        SpringBootServletInitializer {

    public static void main(String[] args) {
        SpringApplication.run(GitlabWebhookProcessingApplication.class, args);
    }

    @Override
    protected SpringApplicationBuilder configure(
            SpringApplicationBuilder application) {
        return application.sources(GitlabWebhookProcessingApplication.class);
    }

}

我将这个类指向我的POM文件,如下所示:

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <start-class>com.chemtech.ci.integration.GitlabWebhookProcessingApplication</start-class>
        <java.version>1.7</java.version>
    </properties>

正如上面的文档所述,这个应该神奇地工作,我的应用程序将被加载并按预期工作。

啊,这里是日志:

Servlet映射:

2015-06-07 20:21:16.870  INFO 3373 --- [ost-startStop-1] o.s.b.c.e.ServletRegistrationBean        : Mapping servlet: 'dispatcherServlet' to [/]
2015-06-07 20:21:16.871  INFO 3373 --- [ost-startStop-1] o.s.b.c.embedded.FilterRegistrationBean  : Mapping filter: 'errorPageFilter' to: [/*]
2015-06-07 20:21:16.872  INFO 3373 --- [ost-startStop-1] o.s.b.c.embedded.FilterRegistrationBean  : Mapping filter: 'characterEncodingFilter' to: [/*]
2015-06-07 20:21:16.872  INFO 3373 --- [ost-startStop-1] o.s.b.c.embedded.FilterRegistrationBean  : Mapping filter: 'hiddenHttpMethodFilter' to: [/*]

控制器动作映射:

2015-06-07 20:21:20.278  INFO 3373 --- [ost-startStop-1] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/webhooks/mergeRequestComment],methods=[POST],params=[],headers=[],consumes=[],produces=[],custom=[]}" onto public void com.chemtech.ci.integration.controller.WebhookController.MergeRequestCommentReceiver(java.lang.String,com.chemtech.ci.integration.model.MergeRequestCommentEventRequestBody)
2015-06-07 20:21:20.282  INFO 3373 --- [ost-startStop-1] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/error],methods=[],params=[],headers=[],consumes=[],produces=[],custom=[]}" onto public org.springframework.http.ResponseEntity<java.util.Map<java.lang.String, java.lang.Object>> org.springframework.boot.autoconfigure.web.BasicErrorController.error(javax.servlet.http.HttpServletRequest)
2015-06-07 20:21:20.282  INFO 3373 --- [ost-startStop-1] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/error],methods=[],params=[],headers=[],consumes=[],produces=[text/html],custom=[]}" onto public org.springframework.web.servlet.ModelAndView org.springframework.boot.autoconfigure.web.BasicErrorController.errorHtml(javax.servlet.http.HttpServletRequest)

重要的是要强调使用带有嵌入式服务器的可执行JAR可以很好地工作。我在这个问题上摸了一会儿,甚至尝试按照其他SO线程的说法做了一些事情:

Spring Boot - custom 404 page with standalone tomcat

http://forum.spring.io/forum/spring-projects/web/745458-spring-boot-v1-0-0-rc3-not-resolving-views-404-error(并非完全相关)

我在这里做错了吗? (好吧,我当然是。这是一个纯粹的修辞问题)

非常感谢任何帮助。

谢谢!

1 个答案:

答案 0 :(得分:11)

嗯,这是一个相当尴尬的答案,但问题是我忘记了在tc Server / Tomcat上部署战争时,默认情况下根上下文将是WAR的名称。

因此,虽然http://server.ip:8080/controller/method不起作用,但http://server.ip:8080/war-package-name/controller/method非常有效。

作为对自己的记录,在星期天晚上工作时永远不要相信自己。

谢谢大家,并希望这有助于将来的某个人!