blob: a4253f65a794207a9aa0c955baf4564ff59b970b [file] [log] [blame]
------
Adding and Filtering External Web Resources
------
Pete Marvin King
Dennis Lundberg
------
2012-09-28
------
~~ Licensed to the Apache Software Foundation (ASF) under one
~~ or more contributor license agreements. See the NOTICE file
~~ distributed with this work for additional information
~~ regarding copyright ownership. The ASF licenses this file
~~ to you under the Apache License, Version 2.0 (the
~~ "License"); you may not use this file except in compliance
~~ with the License. You may obtain a copy of the License at
~~
~~ http://www.apache.org/licenses/LICENSE-2.0
~~
~~ Unless required by applicable law or agreed to in writing,
~~ software distributed under the License is distributed on an
~~ "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
~~ KIND, either express or implied. See the License for the
~~ specific language governing permissions and limitations
~~ under the License.
~~ NOTE: For help with the syntax of this file, see:
~~ http://maven.apache.org/doxia/references/apt-format.html
Adding and Filtering External Web Resources
The default resource directory for all Maven projects is <<<src/main/resources>>> which
will end up in <<<target/classes>>> and in <<<WEB-INF/classes>>> in the WAR. The directory
structure will be preserved in the process.
The WAR Plugin is also capable of including resources not found in the default resource
directory through the <<<webResources>>> parameter.
*Adding web resources
+-------+
<project>
...
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-war-plugin</artifactId>
<version>${project.version}</version>
<configuration>
<webResources>
<resource>
<!-- this is relative to the pom.xml directory -->
<directory>resource2</directory>
</resource>
</webResources>
</configuration>
</plugin>
</plugins>
</build>
...
</project>
+-------+
Using our sample project in the {{{../usage.html}usage section}} with an added external resource, like this:
+----------+
.
|-- pom.xml
|-- resource2
| |-- external-resource.jpg
| `-- image2
| `-- external-resource2.jpg
`-- src
`-- main
|-- java
| `-- com
| `-- example
| `-- projects
| `-- SampleAction.java
|-- resources
| `-- images
| `-- sampleimage.jpg
`-- webapp
|-- WEB-INF
| `-- web.xml
|-- index.jsp
`-- jsp
`-- websource.jsp
+----------+
would end up in the WAR as:
+----------+
documentedproject-1.0-SNAPSHOT.war
|-- META-INF
| |-- MANIFEST.MF
| `-- maven
| `-- com.example.projects
| `-- documentedproject
| |-- pom.properties
| `-- pom.xml
|-- WEB-INF
| |-- classes
| | |-- com
| | | `-- example
| | | `-- projects
| | | `-- SampleAction.class
| | `-- images
| | `-- sampleimage.jpg
| `-- web.xml
|-- external-resource.jpg
|-- image2
| `-- external-resource2.jpg
|-- index.jsp
`-- jsp
`-- websource.jsp
+----------+
<<<external-resource2.jpg>>> and <<<image2>>> are copied to the root of the WAR, preserving the
directory structure.
*Configuring web Resources
<<<webResources>>> is a list of resources. All options of resource are supported.
A web resource
* can have includes/excludes
* can be filtered
* is not limited to the default destination - the root of the WAR
**Includes/Excludes
To include all jpgs in the WAR we can add the following to our POM configuration from above:
+----------+
...
<configuration>
<webResources>
<resource>
<!-- this is relative to the pom.xml directory -->
<directory>resource2</directory>
<!-- the list has a default value of ** -->
<includes>
<include>**/*.jpg</include>
</includes>
</resource>
</webResources>
</configuration>
...
+----------+
To exclude the <<<image2>>> directory from the WAR add this:
+----------+
...
<configuration>
<webResources>
<resource>
<!-- this is relative to the pom.xml directory -->
<directory>resource2</directory>
<!-- there's no default value for this -->
<excludes>
<exclude>**/image2</exclude>
</excludes>
</resource>
</webResources>
</configuration>
...
+----------+
Be careful when mixing includes and excludes, excludes will have a higher priority.
Includes can not override excludes if a resource matches both.
Having this configuration will exclude all jpgs from the WAR:
+----------+
...
<configuration>
<webResources>
<resource>
<!-- this is relative to the pom.xml directory -->
<directory>resource2/</directory>
<!-- the list has a default value of ** -->
<includes>
<include>image2/*.jpg</include>
</includes>
<!-- there's no default value for this -->
<excludes>
<exclude>**/*.jpg</exclude>
</excludes>
</resource>
</webResources>
</configuration>
...
+----------+
Here's another example of how to specify include and exclude patterns:
+----------+
...
<configuration>
<webResources>
<resource>
<!-- this is relative to the pom.xml directory -->
<directory>resource2</directory>
<!-- the default value is ** -->
<includes>
<include>**/pattern1</include>
<include>*pattern2</include>
</includes>
<!-- there's no default value for this -->
<excludes>
<exclude>*pattern3/pattern3</exclude>
<exclude>pattern4/pattern4</exclude>
</excludes>
</resource>
</webResources>
</configuration>
...
+----------+
**Filtering
Using our example above, we can also configure filters for our resources.
We will add a hypothetical <<<configurations>>> directory to our project:
+----------+
.
|-- configurations
| |-- config.cfg
| `-- properties
| `-- config.prop
|-- pom.xml
|-- resource2
| |-- external-resource.jpg
| `-- image2
| `-- external-resource2.jpg
`-- src
`-- main
|-- java
| `-- com
| `-- example
| `-- projects
| `-- SampleAction.java
|-- resources
| `-- images
| `-- sampleimage.jpg
`-- webapp
|-- WEB-INF
| `-- web.xml
|-- index.jsp
`-- jsp
`-- websource.jsp
+----------+
To prevent corrupting your binary files when filtering is enabled, you can configure a list of file extensions that
will not be filtered.
+----------+
...
<configuration>
<!-- the default value is the filter list under build -->
<!-- specifying a filter will override the filter list under build -->
<filters>
<filter>properties/config.prop</filter>
</filters>
<nonFilteredFileExtensions>
<!-- default value contains jpg,jpeg,gif,bmp,png -->
<nonFilteredFileExtension>pdf</nonFilteredFileExtension>
</nonFilteredFileExtensions>
<webResources>
<resource>
<directory>resource2</directory>
<!-- it's not a good idea to filter binary files -->
<filtering>false</filtering>
</resource>
<resource>
<directory>configurations</directory>
<!-- enable filtering -->
<filtering>true</filtering>
<excludes>
<exclude>**/properties</exclude>
</excludes>
</resource>
</webResources>
</configuration>
...
+----------+
*** <<<config.prop>>>
+----------+
interpolated_property=some_config_value
+----------+
*** <<<config.cfg>>>
+----------+
<another_ioc_container>
<configuration>${interpolated_property}</configuration>
</another_ioc_container>
+----------+
The resulting WAR would be:
+----------+
documentedproject-1.0-SNAPSHOT.war
|-- META-INF
| |-- MANIFEST.MF
| `-- maven
| `-- com.example.projects
| `-- documentedproject
| |-- pom.properties
| `-- pom.xml
|-- WEB-INF
| |-- classes
| | |-- com
| | | `-- example
| | | `-- projects
| | | `-- SampleAction.class
| | `-- images
| | `-- sampleimage.jpg
| `-- web.xml
|-- config.cfg
|-- external-resource.jpg
|-- image2
| `-- external-resource2.jpg
|-- index.jsp
`-- jsp
`-- websource.jsp
+----------+
and the content of <<<config.cfg>>> would be:
+----------+
<another_ioc_container>
<configuration>some_config_value</configuration>
</another_ioc_container>
+----------+
<<Note:>> In versions 2.2 and earlier of this plugin the platform encoding was
used when filtering resources. Depending on what that encoding was you could
end up with scrambled characters after filtering. Starting with version 2.3
this plugin respects the property <<<project.build.sourceEncoding>>> when
filtering resources. One notable exception to this is that <<<.xml>>> files
are filtered using the encoding specified inside the xml-file itself.
**Overriding the default destination directory
By default web resources are copied to the root of the WAR, as shown in the previous example.
To override the default destination directory, specify the target path.
+----------+
...
<configuration>
<webResources>
<resource>
...
</resource>
<resource>
<directory>configurations</directory>
<!-- override the destination directory for this resource -->
<targetPath>WEB-INF</targetPath>
<!-- enable filtering -->
<filtering>true</filtering>
<excludes>
<exclude>**/properties</exclude>
</excludes>
</resource>
</webResources>
</configuration>
...
+----------+
Using the sample project the resulting WAR would look like this:
+----------+
documentedproject-1.0-SNAPSHOT.war
|-- META-INF
| |-- MANIFEST.MF
| `-- maven
| `-- com.example.projects
| `-- documentedproject
| |-- pom.properties
| `-- pom.xml
|-- WEB-INF
| |-- classes
| | |-- com
| | | `-- example
| | | `-- projects
| | | `-- SampleAction.class
| | `-- images
| | `-- sampleimage.jpg
| |-- config.cfg
| `-- web.xml
|-- external-resource.jpg
|-- image2
| `-- external-resource2.jpg
|-- index.jsp
`-- jsp
`-- websource.jsp
+----------+