阴影:阴影

全名

org.apache.maven.plugins:maven-shade-plugin:1.4:shade

说明

Mojo 执行着色委托给着色器组件。

属性

  • 需要执行 Maven 2.0 项目。
  • 需要范围内工件的依赖关系解析:runtime.
  • 目标是线程安全的并支持并行构建。
  • 默认绑定到生命周期阶段:package.

可选参数

姓名 类型 自从 描述
工件集 ArtifactSet - 从最终工件中包含/排除的工件。人工制品由通用形式的复合标识符表示 groupId:artifactId:type:classifier。从 1.3 版开始,通配符 '*' 和 '?' 可以在这些复合标识符的子部分中使用以进行模式匹配。为方便起见,语法groupId等价于 groupId:*:*:*,groupId:artifactId等价于groupId:artifactId:*:*groupId:artifactId:classifier等价于 groupId:artifactId:*:classifier。例如:
<artifactSet>
  <includes>
    <include>org.apache.maven:*</include>
  </includes>
  <excludes>
    <exclude>*:maven-core</exclude>
  </excludes>
</artifactSet>

createDependencyReducedPom boolean - 标记是否为着色工件生成简化的 POM。如果设置为true,则已包含在 uber JAR 中的依赖项将从 <dependencies>生成的 POM 部分中删除。减少的 POM 将被命名dependency-reduced-pom.xml 并存储到与阴影工件相同的目录中。
默认值为true
创建SourcesJar boolean - 当为 true 时,它​​也会尝试创建一个源 jar
默认值为: false
过滤器 ArchiveFilter[] - 要使用的存档过滤器。允许您以复合标识符 artifactSet和一组包含/排除文件模式的形式指定工件,以过滤将归档的哪些内容添加到阴影 jar 中。从逻辑的角度来看,包含在排除之前处理​​,因此可以使用包含从存档中收集一组文件,然后使用排除进一步减少该集合。默认情况下,包含所有文件,不排除任何文件。如果多个过滤器应用于一个工件,则匹配文件的交集将包含在最终 JAR 中。例如:
<filters>
  <filter>
    <artifact>junit:junit</artifact>
    <includes>
      <include>org/junit/**</include>
    </includes>
    <excludes>
      <exclude>org/junit/experimental/**</exclude>
    </excludes>
  </filter>
</filters>

最终名称 String - 阴影 artifactId 的名称。如果您想更改本机工件的名称,您可以使用 <build><finalName> 设置。如果将其设置为不同于 <build><finalName> 的值,则不会执行文件替换,即使正在使用 shadedArtifactAttached。
keepDependenciesWithProvidedScope boolean - 如果为 true,则依赖项保留在 pom 中,但范围为“已提供”;如果为 false,则删除依赖项。
默认值为false
最小化Jar boolean 1.4 当为 true 时,依赖项将在类级别上被剥离为仅工件所需的传递外壳。注意: 使用此功能需要 Java 1.5 或更高版本。
默认值为false
输出目录 File - 着色工件的目标目录。
默认值为${project.build.directory}
输出文件 File 1.3 着色工件的输出文件的路径。设置此参数后,创建的存档既不会替换项目的主要工件,也不会附加。因此,此参数会导致参数finalNameshadedArtifactAttached和 在使用shadedClassifierNamecreateDependencyReducedPom被忽略。
促进传递依赖 boolean - 当为真时,移除依赖的传递依赖被提升为直接依赖。这应该允许用新的阴影 jar 替换已删除的 deps,并且一切都应该仍然有效。
默认值为false
搬迁 PackageRelocation[] - 要搬迁的包裹。例如:
<relocations>
  <relocation>
    <pattern>org.apache</pattern>
    <shadedPattern>hidden.org.apache</shadedPattern>
    <includes>
      <include>org.apache.maven.*</include>
    </includes>
    <excludes>
      <exclude>org.apache.maven.Public*</exclude>
    </excludes>
  </relocation>
</relocations>
注意:仅从 1.4 版开始支持包含。
shadedArtifactAttached boolean - 定义是否应将着色工件作为分类器附加到原始工件。如果为 false,阴影 jar 将是项目的主要工件
默认值为: false
shadedArtifactId String - 阴影 artifactId 的名称。因此,您可能希望使用不同的 artifactId 并保留标准版本。如果原始 artifactId 是“foo”,那么最终的 artifact 将类似于 foo-1.0.jar。因此,如果您更改 artifactId,您可能会得到类似 foo-special-1.0.jar 的内容。
默认值为${project.artifactId}
shadedClassifierName String - 在附加阴影工件的情况下使用的分类器的名称。
默认值为shaded
阴影组过滤器 String - 如果指定,这将仅包括具有以 this 开头的 groupIds 的工件。
变压器 ResourceTransformer[] - 要使用的资源转换器。有关可用变压器及其配置的更多信息,请参阅“示例”部分。

参数详情

工件集

从最终工件中包含/排除的工件。人工制品由通用形式的复合标识符表示 groupId:artifactId:type:classifier。从 1.3 版开始,通配符 '*' 和 '?' 可以在这些复合标识符的子部分中使用以进行模式匹配。为方便起见,语法groupId等价于 groupId:*:*:*,groupId:artifactId等价于groupId:artifactId:*:*groupId:artifactId:classifier等价于 groupId:artifactId:*:classifier。例如:
<artifactSet>
  <includes>
    <include>org.apache.maven:*</include>
  </includes>
  <excludes>
    <exclude>*:maven-core</exclude>
  </excludes>
</artifactSet>
  • 类型org.apache.maven.plugins.shade.mojo.ArtifactSet
  • 必需No

createDependencyReducedPom

标记是否为着色工件生成简化的 POM。如果设置为true,则已包含在 uber JAR 中的依赖项将从 <dependencies>生成的 POM 部分中删除。减少的 POM 将被命名dependency-reduced-pom.xml 并存储到与阴影工件相同的目录中。
  • 类型boolean
  • 必需No
  • 表达式${createDependencyReducedPom}
  • 默认true

创建SourcesJar

当为 true 时,它​​也会尝试创建一个源 jar
  • 类型boolean
  • 必需No
  • 表达式${createSourcesJar}
  • 默认false

过滤器

要使用的存档过滤器。允许您以复合标识符 artifactSet和一组包含/排除文件模式的形式指定工件,以过滤将归档的哪些内容添加到阴影 jar 中。从逻辑的角度来看,包含在排除之前处理​​,因此可以使用包含从存档中收集一组文件,然后使用排除进一步减少该集合。默认情况下,包含所有文件,不排除任何文件。如果多个过滤器应用于一个工件,则匹配文件的交集将包含在最终 JAR 中。例如:
<filters>
  <filter>
    <artifact>junit:junit</artifact>
    <includes>
      <include>org/junit/**</include>
    </includes>
    <excludes>
      <exclude>org/junit/experimental/**</exclude>
    </excludes>
  </filter>
</filters>
  • 类型org.apache.maven.plugins.shade.mojo.ArchiveFilter[]
  • 必需No

最终名称

阴影 artifactId 的名称。如果您想更改本机工件的名称,您可以使用 <build><finalName> 设置。如果将其设置为不同于 <build><finalName> 的值,则不会执行文件替换,即使正在使用 shadedArtifactAttached。
  • 类型java.lang.String
  • 必需No
  • 表达式${finalName}

keepDependenciesWithProvidedScope

如果为 true,则依赖项保留在 pom 中,但范围为“已提供”;如果为 false,则删除依赖项。
  • 类型boolean
  • 必需No
  • 表达式${keepDependenciesWithProvidedScope}
  • 默认false

最小化罐

当为 true 时,依赖项将在类级别上被剥离为仅工件所需的传递外壳。注意: 使用此功能需要 Java 1.5 或更高版本。
  • 类型boolean
  • 1.4
  • 必需No
  • 默认false

输出目录

着色工件的目标目录。
  • 类型java.io.File
  • 必需No
  • 默认${project.build.directory}

输出文件

着色工件的输出文件的路径。设置此参数后,创建的存档既不会替换项目的主要工件,也不会附加。因此,此参数会导致参数finalNameshadedArtifactAttached和 在使用shadedClassifierNamecreateDependencyReducedPom被忽略。
  • 类型java.io.File
  • 1.3
  • 必需No

促进传递依赖

当为真时,移除依赖的传递依赖被提升为直接依赖。这应该允许用新的阴影 jar 替换已删除的 deps,并且一切都应该仍然有效。
  • 类型boolean
  • 必需No
  • 表达式${promoteTransitiveDependencies}
  • 默认false

搬迁

要搬迁的包裹。例如:
<relocations>
  <relocation>
    <pattern>org.apache</pattern>
    <shadedPattern>hidden.org.apache</shadedPattern>
    <includes>
      <include>org.apache.maven.*</include>
    </includes>
    <excludes>
      <exclude>org.apache.maven.Public*</exclude>
    </excludes>
  </relocation>
</relocations>
注意:仅从 1.4 版开始支持包含。
  • 类型org.apache.maven.plugins.shade.mojo.PackageRelocation[]
  • 必需No

shadedArtifact附加

定义是否应将着色工件作为分类器附加到原始工件。如果为 false,阴影 jar 将是项目的主要工件
  • 类型boolean
  • 必需No
  • 表达式${shadedArtifactAttached}
  • 默认false

shadedArtifactId

阴影 artifactId 的名称。因此,您可能希望使用不同的 artifactId 并保留标准版本。如果原始 artifactId 是“foo”,那么最终的 artifact 将类似于 foo-1.0.jar。因此,如果您更改 artifactId,您可能会得到类似 foo-special-1.0.jar 的内容。
  • 类型java.lang.String
  • 必需No
  • 表达式${shadedArtifactId}
  • 默认${project.artifactId}

shadedClassifierName

在附加阴影工件的情况下使用的分类器的名称。
  • 类型java.lang.String
  • 必需No
  • 表达式${shadedClassifierName}
  • 默认shaded

阴影组过滤器

如果指定,这将仅包括具有以 this 开头的 groupIds 的工件。
  • 类型java.lang.String
  • 必需No
  • 表达式${shadedGroupFilter}

变压器

要使用的资源转换器。有关可用变压器及其配置的更多信息,请参阅“示例”部分。
  • 类型org.apache.maven.plugins.shade.resource.ResourceTransformer[]
  • 必需No