【发布时间】:2017-07-16 19:12:18
【问题描述】:
我终于写完了一个非常“简单”的 hello world 项目。
当我从我的 IDE 运行它时,它工作得很好。
当我在 Windows 10 上运行 jar 并转到 localhost(我在端口 80 上运行)然后我看到网页并且一切正常。
一旦我将同一个 jar 放到我的 debian 服务器上,该服务器安装了与我的 windows 机器相同的 mysql 和 java(并且没有安装或配置其他任何东西),我尝试导航到我得到的 ip 地址
Whitelabel Error Page
This application has no explicit mapping for /error, so you are seeing this as a fallback.
Sun Feb 26 02:54:40 UTC 2017
There was an unexpected error (type=Not Found, status=404).
Not Found
这告诉我 spring boot 正在运行(因为第二次我关闭它我无法再访问同一页面),但是我似乎无法导航到我可以在我的 windows 机器上的任何页面.
我完全不知道我在这里做错了什么。
编辑:
感谢 Oleksandr Shpota,我明白了为什么事情不起作用。我的 jar 不包含我的 freemarker 文件。
我的 build.gradle
apply plugin: 'java'
apply plugin: 'idea'
apply plugin: 'jetty'
apply plugin: 'war'
apply plugin: 'org.springframework.boot'
repositories {
mavenCentral()
}
dependencies {
compile("org.springframework.boot:spring-boot-starter-web:1.5.1.RELEASE") {
exclude module: "spring-boot-starter-tomcat"
}
compile group: 'org.springframework.boot', name: 'spring-boot-starter-jetty', version: '1.5.1.RELEASE'
compile group: 'org.springframework.boot', name: 'spring-boot-starter-actuator', version: '1.5.1.RELEASE'
compile group: 'org.springframework', name: 'spring-webmvc', version: '4.3.6.RELEASE'
compile group: 'org.springframework', name: 'spring-context-support', version: '4.3.6.RELEASE'
compile group: 'org.springframework', name: 'spring-orm', version: '4.3.6.RELEASE'
compile group: 'javax.servlet', name: 'javax.servlet-api', version: '3.1.0'
compile group: 'org.freemarker', name: 'freemarker', version: '2.3.23'
compile group: 'mysql', name: 'mysql-connector-java', version: '6.0.5'
compile group: 'org.hibernate', name: 'hibernate-core', version: '5.1.4.Final'
compile group: 'commons-validator', name: 'commons-validator', version: '1.5.1'
compile group: 'junit', name: 'junit', version: '4.12'
compile group: 'org.springframework.boot', name: 'spring-boot-starter-test', version: '1.5.1.RELEASE'
}
task wrapper(type: Wrapper) {
gradleVersion = '2.2'
}
buildscript {
repositories {
mavenCentral()
}
dependencies {
classpath("org.springframework.boot:spring-boot-gradle-plugin:1.5.1.RELEASE")
}
}
jar {
from {
(configurations.runtime).collect {
it.isDirectory() ? it : zipTree(it)
}
}
baseName = 'carefree-cooking'
version = '0.1.0'
manifest {
attributes 'Main-Class': 'carefree.cooking.Application'
}
}
springBoot {
executable = true
}
sourceCompatibility = 1.8
targetCompatibility = 1.8
用于配置 FreeMarker 的我的 Bean
@Bean(name = "freemarkerConfig")
public FreeMarkerConfigurer freemarkerConfig()
{
FreeMarkerConfigurer configurer = new FreeMarkerConfigurer();
configurer.setTemplateLoaderPath("/");
return configurer;
}
@Bean(name = "viewResolver")
public FreeMarkerViewResolver viewResolver()
{
FreeMarkerViewResolver viewResolver = new FreeMarkerViewResolver();
viewResolver.setPrefix("WEB-INF/template/");
viewResolver.setSuffix(".ftl");
return viewResolver;
}
我的索引控制器
@RequestMapping()
public String index(ModelMap model)
{
log.info("======= We are in index controller going to load page");
return "page";
}
page.ftl 在src\main\webapp\WEB-INF\template\page.ftl 中
所以这里的问题是,当我构建我的 jar 时,page.ftl 不包括在内,webapp 目录也不包括在内。
【问题讨论】:
-
您能否发布您在 IDE 或终端中看到的控制台日志?
-
所以您正在构建一个 jar 并期望它的行为与
war完全相同?此外,Spring Boot 已经提供了开箱即用的免费标记支持,您无需为其配置任何内容(它适用于jar和war布局)。我还建议清理您的构建文件,因为您已经拥有spring-boot-starter-web,但再次声明了一个 spring 版本(以消除版本冲突)。您还可以删除大多数依赖项的版本,因为 Spring Boot 插件会处理这个问题。
标签: java web-services spring-boot server debian