解决:我将应用程序从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 回答
看起来应用程序部署在ROOT上下文中 . 如果上下文路径为空字符串,则会出现这种情况 . 对于前:
因此,您的应用程序应该可以在“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.xml
”https://tomcat.apache.org/tomcat-7.0-doc/config/context.html#Naming尝试使用最新的网络应用程序版本,并确保仔细检查拼写或缺少标签 .