我有简单的Spring启动应用程序,它作为独立应用程序运行。我开始使用在线指南转换为WAR。
buildscript {
repositories {
mavenCentral()
}
dependencies {
classpath("org.springframework.boot:spring-boot-gradle-plugin:1.5.4.RELEASE")
}
}
apply plugin: 'java'
apply plugin: 'idea'
apply plugin: 'org.springframework.boot'
apply plugin: 'war'
bootRun {
addResources = true
}
war {
baseName = 'simulator'
version = '1.0.0'
}
repositories {
mavenCentral()
maven { url 'https://jitpack.io' }
}
sourceCompatibility = 1.8
targetCompatibility = 1.8
dependencies {
compile("org.springframework.boot:spring-boot-starter-freemarker")
compile group: 'org.freemarker', name: 'freemarker', version: '2.3.23'
providedRuntime 'org.springframework.boot:spring-boot-starter-tomcat'
testCompile('org.springframework.boot:spring-boot-starter-test')
}
初始化器:
@SpringBootApplication
public class Application extends SpringBootServletInitializer {
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
return application.sources(Application.class);
}
public static void main(String[] args) throws Exception {
SpringApplication.run(Application.class, args);
}
}
组装:
c:\dev\projekty\Simulator>gradlew war
:compileJava
:processResources
:classes
:war
BUILD SUCCESSFUL
Total time: 3.96 secs
但没有创造战争。为什么呢?
答案 0 :(得分:3)
可能会生成war
,而不是在您期望的地方。添加到您的构建脚本
logger.lifecycle "war.archivePath = $war.archivePath"
它将记录您可以找到WAR的位置。
答案 1 :(得分:3)
在我的情况下,使用spring-boot-gradle-plugin:2.0.0.RELEASE
和Gradle 4.2
由于某种原因bootWar
没有被gradlew war
触发。所以,我刚刚执行了下面的命令并生成了war文件:
./gradlew bootWar
答案 2 :(得分:0)
SpringBoot禁用战争任务。只需在脚本中重新启用它即可。我不喜欢BootWar,后者为传统战争部署创建了lib提供的文件夹和其他org文件夹类。
war {
enabled= true
}