繁体   English   中英

尝试访问Tomcat上已部署的战争时获取HTTP状态404

[英]Get HTTP Status 404 when trying to access deployed war on Tomcat

已解决:我将应用程序从spring-boot转换为标准spring mvc,现在可以使用了。 感谢所有尝试提供帮助的人。 仍然不确定问题是什么,但我现在已经开始解决了。


我正在尝试将Web应用程序部署到tomcat7。这些应用程序是使用spring-boot构建的,并使用maven打包。

我将战争放在webapps文件夹中,并且已成功部署:

2015年7月31日,下午1:22:05 org.apache.catalina.startup.HostConfigdeployWAR

INFO:部署Web应用程序归档文件/var/lib/tomcat7/webapps/application.war

2015年7月31日1:22:09 PM org.apache.catalina.startup.HostConfig deployWAR

信息:部署Web应用程序存档/var/lib/tomcat7/webapps/Application.war

2015年7月31日1:22:10 PM org.apache.catalina.startup.HostConfig deployDirectory

INFO:部署Web应用程序目录/ var / lib / tomcat7 / webapps / ROOT

2015年7月31日,下午1:22:11 org.apache.coyote.AbstractProtocol开始

INFO:启动ProtocolHandler [“ http-bio-8080”]

2015年7月31日1:22:11 PM org.apache.catalina.startup.Catalina开始

INFO:服务器在6796毫秒内启动

但是,当我尝试通过浏览器访问它们时,我收到一条404消息(请求的资源不可用。)。 我可以看到ROOT索引并转到管理器应用程序,在该应用程序中将它们正确标识为Spring MVC,并告知它们已部署并正在运行。 单击管理器中的链接可以得到相同的结果。 catalina.out没告诉我任何事情。 服务器启动消息后,它不再向我提供任何信息。

编辑更多信息这是应用程序的web.xml

<web-app 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>Spring MVC Application</display-name>

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

    <servlet-mapping>
        <servlet-name>mvc-dispatcher</servlet-name>
        <url-pattern>/*</url-pattern>
    </servlet-mapping>
</web-app>

控制器处理索引请求:

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Controller;
import org.springframework.ui.ModelMap;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;

@Controller
@RequestMapping("/")
/**
 * Default Controller.
 */
class HelloController {
    /**
     * Implementation of logging interface in SL4J.
     */
    private static final Logger LOGGER = LoggerFactory.getLogger
            (HelloController.class);

    /**
     * Constructs a new Hello Controller
     */
    public HelloController() {
        LOGGER.trace("Created hello controller");
    }

    /**
     * Prints the message on the screen
     * @param model the model to add the message too
     * @return a String
     */
    @RequestMapping(method = RequestMethod.GET)
    public String printWelcome(final ModelMap model) {
        model.addAttribute("message", "Hello world!");
        return "hello";
    }
}

我尝试访问的URL是http:// localhost:8080 / application /http:// localhost:8080 / Application /

我也曾在Tomcat 8中尝试过并得到相同的问题。 我尝试复制ROOT文件夹并将其重命名为应用程序,并且可以正常访问。 似乎与战争有关?

<web-app 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">

尝试使用最新的网络应用版本,并确保非常仔细地检查拼写或缺少标签。

看来该应用程序是在ROOT上下文下部署的。 如果上下文路径为空字符串,则将是这种情况。 例如:

<Context path="" docBase="${catalina.home}/webapps/application.war" >

因此,您的应用程序应该在“ http:localhost:8080 /”上可用。 如果您希望该应用程序在“ http:localhost:8080 / applicaiton”上可用,则有两种方法:

  1. 如果要在server.xml中定义“ <Context> ”元素,则将其定义为: <Context path="/application" docBase="${catalina.home}/webapps/application.war">

  2. 按照下面的文档,您需要在服务器的主机目录中添加名称为“ application.xml”的上下文xml。例如-“ {catalina.base}/conf/Catalina/localhost/application.xmlhttps:/ /tomcat.apache.org/tomcat-7.0-doc/config/context.html#Naming

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM