maven-war-plugin.fml.faq.fml Maven / Gradle / Ivy
How is filtering done in the WAR plugin?
To enable filtering of web.xml
you must configure the war plugin as this:
Examples can be found here.
How does the classifier affect artifacts in my war project?
When used, the copy of the artifact in your project will have the classifier appended to its
filename. This can be used to differentiate duplicate artifacts.
How do I exclude transitive dependencies from my project?
Give it a "provided" scope.
What's the difference between using dependentWarExclude and provided scope?
dependentWarExclude
is used in war overlays for excluding dependent
war files from being included in the exploded war.
How do I exclude files in my web resources?
Use the webResources
exclude
parameter to identify the tokens to use for the filtering.
How do I exclude files when doing war overlays?
Use the dependentWarExcludes
parameter to identify the tokens to use for the filtering.
For more information refer to Adding and Filtering
External Web Resources.
Where can I find the documentation for the plugin's configuration?
For each goal, you can use the documentation from the plugin site.
If you need a specific version, generate it using mvn site:site
or use:
How do I create a jar containing the classes in my webapp?
If you would simply like to package the classes and resources as a jar in WEB-INF/lib
rather than as loose files under WEB-INF/classes
, use the following configuration:
If you need to re-use this jar in another project, the recommended approach is to move the classes to a
separate module that builds a jar, and then declare a dependency on that jar from your webapp as well as from
any other projects that need it.
If you can't move the classes to another project, you can deploy the classes and resources included in
your webapp as an "attached" artifact, with a classifier, by using the following configuration:
This will result in two artifacts being deployed: mywebapp-1.0-SNAPSHOT.war
and mywebapp-1.0-SNAPSHOT-classes.jar
.