Java WkHtmlToPdf Wrapper

A Java based wrapper for the wkhtmltopdf command line tool. As the name implies, it uses WebKit to convert HTML documents to PDFs.

License

License

Categories

Categories

Java Languages PDF Data
GroupId

GroupId

com.github.jhonnymertz
ArtifactId

ArtifactId

java-wkhtmltopdf-wrapper
Last Version

Last Version

1.1.13-RELEASE
Release Date

Release Date

Type

Type

jar
Description

Description

Java WkHtmlToPdf Wrapper
A Java based wrapper for the wkhtmltopdf command line tool. As the name implies, it uses WebKit to convert HTML documents to PDFs.
Project URL

Project URL

https://github.com/jhonnymertz/java-wkhtmltopdf-wrapper
Source Code Management

Source Code Management

https://github.com/jhonnymertz/java-wkhtmltopdf-wrapper

Download java-wkhtmltopdf-wrapper

How to add to project

<!-- https://jarcasting.com/artifacts/com.github.jhonnymertz/java-wkhtmltopdf-wrapper/ -->
<dependency>
    <groupId>com.github.jhonnymertz</groupId>
    <artifactId>java-wkhtmltopdf-wrapper</artifactId>
    <version>1.1.13-RELEASE</version>
</dependency>
// https://jarcasting.com/artifacts/com.github.jhonnymertz/java-wkhtmltopdf-wrapper/
implementation 'com.github.jhonnymertz:java-wkhtmltopdf-wrapper:1.1.13-RELEASE'
// https://jarcasting.com/artifacts/com.github.jhonnymertz/java-wkhtmltopdf-wrapper/
implementation ("com.github.jhonnymertz:java-wkhtmltopdf-wrapper:1.1.13-RELEASE")
'com.github.jhonnymertz:java-wkhtmltopdf-wrapper:jar:1.1.13-RELEASE'
<dependency org="com.github.jhonnymertz" name="java-wkhtmltopdf-wrapper" rev="1.1.13-RELEASE">
  <artifact name="java-wkhtmltopdf-wrapper" type="jar" />
</dependency>
@Grapes(
@Grab(group='com.github.jhonnymertz', module='java-wkhtmltopdf-wrapper', version='1.1.13-RELEASE')
)
libraryDependencies += "com.github.jhonnymertz" % "java-wkhtmltopdf-wrapper" % "1.1.13-RELEASE"
[com.github.jhonnymertz/java-wkhtmltopdf-wrapper "1.1.13-RELEASE"]

Dependencies

compile (3)

Group / Artifact Type Version
org.apache.commons : commons-lang3 jar 3.9
commons-io : commons-io jar 2.6
org.slf4j : slf4j-api jar 1.7.25

test (4)

Group / Artifact Type Version
org.slf4j : slf4j-simple jar 1.7.5
junit : junit jar 4.13.1
org.apache.pdfbox : pdfbox jar 2.0.16
org.mockito : mockito-core jar 3.3.3

Project Modules

There are no modules declared in this project.

Java WkHtmlToPdf Wrapper Build Status

A Java based wrapper for the wkhtmltopdf command line tool. As the name implies, it uses WebKit to convert HTML documents to PDFs.

Requirements

wkhtmltopdf must be installed and working on your system.

Wrapper project dependency

Make sure you have Java Wrapper dependency added to your project.

If you are using Gradle/Maven, see example below:

Gradle

In your build.gradle:

dependencies {
    compile 'com.github.jhonnymertz:java-wkhtmltopdf-wrapper:1.1.13-RELEASE'
}

Maven

In your pom.xml:

<dependency>
    <groupId>com.github.jhonnymertz</groupId>
    <artifactId>java-wkhtmltopdf-wrapper</artifactId>
    <version>1.1.13-RELEASE</version>
</dependency>

Usage and Examples

Pdf pdf = new Pdf();

pdf.addPageFromString("<html><head><meta charset=\"utf-8\"></head><h1>Müller</h1></html>");
pdf.addPageFromUrl("http://www.google.com");

// Add a Table of Contents
pdf.addToc();

// The `wkhtmltopdf` shell command accepts different types of options such as global, page, headers and footers, and toc. Please see `wkhtmltopdf -H` for a full explanation.
// All options are passed as array, for example:
pdf.addParam(new Param("--no-footer-line"), new Param("--header-html", "file:///header.html"));
pdf.addParam(new Param("--enable-javascript"));

// Add styling for Table of Contents
pdf.addTocParam(new Param("--xsl-style-sheet", "my_toc.xsl"));

// Save the PDF
pdf.saveAs("output.pdf");

Xvfb Support

XvfbConfig xc = new XvfbConfig();
xc.addParams(new Param("--auto-servernum"), new Param("--server-num=1"));

WrapperConfig wc = new WrapperConfig();
wc.setXvfbConfig(xc);

Pdf pdf = new Pdf(wc);
pdf.addPageFromUrl("http://www.google.com");

pdf.saveAs("output.pdf");

wkhtmltopdf exit codes

wkhtmltopdf may return non-zero exit codes to denote warnings, you can now set the Pdf object to allow this:

Pdf pdf = new Pdf();
pdf.addPageFromUrl("http://www.google.com");

pdf.setAllowMissingAssets();
// or:  
pdf.setSuccessValues(Arrays.asList(0, 1));

pdf.saveAs("output.pdf");

Cleaning up temporary files

After the PDF generation, the library automatically cleans up the temporary files created. However, there may be situations in which the Pdf object is created but no PDF is generated. To avoid increasing the temp folder size and having problems, you can force the deletion of all temporary files created by the library by:

Pdf pdf = new Pdf();
pdf.cleanAllTempFiles();

This is not an official Wkhtmltopdf product

This library is not an official Wkhtmltopdf product. Support is available on a best-effort basis via github issue tracking. Pull requests are welcomed.

Bugs

  • Tests are incomplete

Known issues

Output of wkhtmltopdf is being added to resulting pdf (Issue #19)

  • Starting from 1.1.10-RELEASE version, there is a method saveAsDirect(String path), which executes wkhtmltopdf passing the path as output for wkhtmltopdf, instead of the standard input -. This saves the results directly to the specified file path.

Because this library relies on wkhtmltopdf, it does not support concurrent PDF generations.

License

This project is available under MIT Licence.

Versions

Version
1.1.13-RELEASE
1.1.12-RELEASE
1.1.11-RELEASE
1.1.10-RELEASE
1.1.9-RELEASE
1.1.8-RELEASE
1.1.7-RELEASE
1.1.6-RELEASE