首页 文章

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

提问于
浏览
0

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


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

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

2015年7月31日下午1:22:05 org.apache.catalina.startup.HostConfigdeployWAR信息:部署Web应用程序存档/var/lib/tomcat7/webapps/application.war 2015年7月31日下午1:22:09组织 . apache.catalina.startup.HostConfig deployWAR INFO:部署Web应用程序存档/var/lib/tomcat7/webapps/Application.war 2015年7月31日下午1:22:10 org.apache.catalina.startup.HostConfig deployDirectory信息:部署Web应用程序目录/ var / lib / tomcat7 / webapps / ROOT Jul 31,2015 1:22:11 PM org.apache.coyote.AbstractProtocol start INFO:Starting ProtocolHandler [“http-bio-8080”] Jul 31,2015 1:22 :晚上11点org.apache.catalina.startup.Catalina启动信息:服务器启动时间为6796 ms

但是,当我尝试通过浏览器访问它时,我收到一条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";
    }
}

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

我也在Tomcat 8中尝试过它并得到同样的问题 . 我尝试复制ROOT文件夹并将副本重命名为应用程序,并可以访问该文件 . 似乎是战争的东西?

2 回答

  • 0

    看起来应用程序部署在ROOT上下文中 . 如果上下文路径为空字符串,则会出现这种情况 . 对于前:

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

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

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

    • 根据以下文档,您需要在服务器的主机目录中按名称"application.xml"添加上下文xml . 对于前 - “ {catalina.base}/conf/Catalina/localhost/application.xmlhttps://tomcat.apache.org/tomcat-7.0-doc/config/context.html#Naming

  • 0
    <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">
    

    尝试使用最新的网络应用程序版本,并确保仔细检查拼写或缺少标签 .

相关问题