跳到主要内容

25、Gradle War 插件

War 插件

War的插件继承自 Java 插件并添加了对组装 web 应用程序的 WAR 文件的支持。它禁用了 Java 插件生成默认的 JAR archive,并添加了一个默认的 WAR archive 任务。

用法

要使用War 的插件,请在构建脚本中包含以下语句:

使用 War 插件

build.gradle

apply plugin: 'war'  

任务

War插件向 project 中添加了以下任务。

表26.1. War 插件 – 任务

任务名称 依赖于 类型 描述
war compile War 组装应用程序 WAR 文件。

War插件向 Java 插件所加入的 tasks 添加了以下的依赖。

表26.2. War 插件 – 额外的 task 依赖

任务名称 依赖于
assemble war

图26.1. War 插件 – tasks

 

项目布局

表26.3. War 插件 – 项目布局

目录 意义
from <s1>'src/main/webapp'</s1> Web 应用程序源代码

依赖管理

War插件添加了两个依赖配置: providedCompile 和 providedRuntime。虽然它们有各自的compile 和 runtime 配置,但这些配置有相同的作用域,只是它们不会添加到 WAR 文件中。要特别注意,这些 provided 配置的传递使用。假设你添加 commons-httpclient:commons-httpclient:3.0 依赖到任何一个 provided 配置。这个依赖又依赖于 commons-codec。这意味着 httpclient 和 commons-codec 都不会添加到你的 WAR 中,即使 commons-codec 是 compile 配置上的一个显示依赖。如果你不想要这种传递行为,只是把 provided 依赖声明成和commons-httpclient:commons-httpclient:3.0@jar 一样。

公约属性

表26、4. War 插件 – 目录属性

属性名称 类型 默认值 描述
webAppDirName String from <s1>'src/main/webapp'</s1> web 应用程序源目录的名称,是一个相对于项目目录的目录名称。
webAppDir File (read-only) webAppDirName Web 应用程序的源目录。

这些属性由一个 WarPluginConvention 公约对象提供。

War

Wartask 的默认行为是将 src/main/webapp 的内容复制到 archive 的根目录下。你的 webapp 目录自然可能包含一个 WEB-INF 子目录,这个子目录可能还再包含一个 web.xml 文件。已编译的类被编译进 WEB-INF/classes。所有 runtime 配置的依赖被复制到 WEB-INF/lib。

自定义

下面是一个示例,展示了最重要的自定义选项:

war 插件的自定义

build.gradle

configurations {
   moreLibs
}
repositories {
   flatDir { dirs "lib" }
   mavenCentral()
}
dependencies {
    compile module(":compile:1.0") {
        dependency ":compile-transitive-1.0@jar"
        dependency ":providedCompile-transitive:1.0@jar"
    }
    providedCompile "javax.servlet:servlet-api:2.5"
    providedCompile module(":providedCompile:1.0") {
        dependency ":providedCompile-transitive:1.0@jar"
    }
    runtime ":runtime:1.0"
    providedRuntime ":providedRuntime:1.0@jar"
    testCompile 'junit:junit:4.11'
}
    moreLibs ":otherLib:1.0"
}
war {
    from 'src/rootContent' // adds a file-set to the root of the archive
    webInf { from 'src/additionalWebInf' } // adds a file-set to the WEB-INF dir.
    classpath fileTree('additionalLibs') // adds a file-set to the WEB-INF/lib dir.
    classpath configurations.moreLibs // adds a configuration to the WEB-INF/lib dir.
    webXml = file('src/someWeb.xml') // copies a file to WEB-INF/web.xml
}  

当然,你可以用一个定义了 excludes 和 includes 的闭包来配置不同的文件集。