Skip to content

dernasherbrezon/fingerprint-maven-plugin

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

fingerprint-maven-plugin Main Workflow Quality Gate Status

Fingerprint and optimize web resources.

About

This plugin performs several optimizations:

  • Resource fingerprinting.
  • JS/CSS minification. yuicompressor is used
  • HTML minification.

Fingerprinting

During this process plugin calculates file checksum and prepends it to the file name. All links to this filename will be changed to the fingerprinted version. Original file will be deleted. Fingerprinting used to improve web resource caching. If file checksum is not changed, then the name will be the same and it is safe to add max expires header. Once file contents are changed, checksum will be changed as well. This plugin filters out (recursivly) source directory, detects any resources using the patterns below and copy result (if needed) to the target directory.

The following patterns are used to detect resources eligible for fingerprinting:

  • <link[^>]+href=["'](.*?)["'][^>]*>
  • ["']([^\s]*?\.js)["']
  • <img[^>]+src=["'](.*?)["'][^>]+>
  • url\(\s*["']?(.*?)["']?\s*\)
  • <c:url[^>]+value="(.*?)"[^>]+>

After fingerprinting it is safe to add max expires header.

Requirements

  • All resources should have absolute paths:
    • Valid: <img src="/img/test.png">
    • Invalid: <img src="test.png">
  • JSP contextPath is supported:
    • Valid: <img src="${pageContext.request.contextPath}/img/test.png">
    • Invalid: <img src="${ pageContext.request.contextPath }/test.png">
  • All resources should point to existing files without any pre-processing:
    • Valid: <img src="/img/test.png">
    • Invalid: <img src="<c:if test="${var}">/img/test.png</c:if>"
    • Invalid: <img src="${seome.variable}/img/test.png"

HTML minification

During html minification:

  • all extra spaces between tags will be removed. Except pre.
  • type="text" will be removed from input tags since it's default type.

Configuration

  • Configure plugin in pom.xml:
			<plugin>
				<groupId>com.aerse.maven</groupId>
				<artifactId>fingerprint-maven-plugin</artifactId>
				<version>3.6</version>
				<executions>
					<execution>
						<phase>package</phase>
						<goals>
							<goal>generate</goal>
						</goals>
					</execution>
				</executions>
				<configuration>
					<excludeResources>
						<excludeResource>://</excludeResource>
						<excludeResource>//</excludeResource>
						<excludeResource>data:</excludeResource>
					</excludeResources>
<!-- ${basedir}/src/main/webapp by default -->
					<sourceDirectory>${basedir}/target/webcombined</sourceDirectory>
<!-- ${project.build.directory}/optimized-webapp by default -->
					<targetDirectory>${basedir}/target/optimized-webapp</targetDirectory>
<!-- Optional: set to 'false' to disable minification of HTML, JS and/or CSS. -->
					<minifyHtml>true</minifyHtml>
					<minifyJs>true</minifyJs>
					<minifyCss>true</minifyCss>
<!-- Remove unnecessary spaces between tags. Make single line page. Takes into consideration <pre> tags -->
					<htmlExtensions>
						<htmlExtension>html</htmlExtension>
						<htmlExtension>jsp</htmlExtension>
						<htmlExtension>tag</htmlExtension>
					</htmlExtensions>
					<extensionsToFilter>
						<extensionToFilter>html</extensionToFilter>
						<extensionToFilter>jsp</extensionToFilter>
						<extensionToFilter>tag</extensionToFilter>
						<extensionToFilter>css</extensionToFilter>
						<extensionToFilter>js</extensionToFilter>
					</extensionsToFilter>
<!-- cdn host. Not required. For example using "//accountname.r.worldssl.net": /css/bootstrap.css -> //accountname.r.worldssl.net/css/<md5>bootstrap.css -->
					<cdn>${cdn}</cdn>
<!-- fingerprinted filename. Could be [name].[ext]?hash=[hash] -->
					<namePattern>[hash][name].[ext]</namePattern>
				</configuration>
			</plugin>
  • Configure apache or nginx with max expires header. The following example is the configuration for nginx:
        location ~ ^/.+\.(ico|jpg|jpeg|gif|pdf|jar|png|js|css|txt|epf|ttf|svg|woff)$ {
            root         <your root content>;
            expires max;
            add_header Cache-Control public;
        }