Edit in GitHubLog an issue

Quickstarts

This quickstart will guide you through the necessary steps to setup and make a request to the Document Generation API.
Use Document Generation API to merge JSON data into Word based document templates and produce high fidelity PDF and Word documents from any application.
To learn more about the Document Generation, read Overview

Live Demo#

The Document Generation API Demo demonstrates how easy it is to generate customized documents from Word-based document templates and input JSON data.

How It Works#

This section details out step by step instructions to get started with Document Generation.

1. Author your Word-based document templates#

Authoring a document template involves adding the template tags to your Word document as illustrated below:

Document template with heading and template tags


Using MS Word Add-In
The quickest way to author a Word-based document template is by using Adobe Document Generation Word Add-In. The Add-in significantly reduces the time and effort required to insert the template tags into a Word document.

Manually
Alternatively, you can create a document template by manually inserting the template tags into a Word document. Here are some prebuilt sample document templates to start with.

2. Prepare your JSON data#

Compose the JSON data that will be merged with your Word-based document template.

Copied to your clipboard
1{
2 "Client" : {
3 "Name" : "Some Corp Inc",
4 "Address" : "Somewhere Street"
5 }
6}

3. Generate PDF and Word documents using Document Generation API#

Once you are ready with the Word-based document template and the JSON data, the final step is to invoke the Document Generation API to generate the output PDF or Word documents.
There are two ways to access the Document Generation API:

3.1. REST API
You can use our cloud based REST API to generate documents.

3.2. PDF Services SDK
Alternatively, you can use our offering through PDF Services SDK.


Generate PDF or Word document#

The sample below generates the output document in the PDF format. Similarly, you can specify DOCX as the OutputFormat to generate Word documents.

Copied to your clipboard
1// Get the samples from https://www.adobe.com/go/pdftoolsapi_java_samples
2// Run the sample:
3// mvn -f pom.xml exec:java -Dexec.mainClass=com.adobe.pdfservices.operation.samples.documentmerge.MergeDocumentToDOCX
4
5 package com.adobe.pdfservices.operation.samples.documentmerge;
6
7 public class MergeDocumentToPDF {
8
9 // Initialize the logger.
10 private static final Logger LOGGER = LoggerFactory.getLogger(MergeDocumentToPDF.class);
11
12 public static void main(String[] args) {
13
14 try {
15
16 // Initial setup, create credentials instance.
17 Credentials credentials = Credentials.serviceAccountCredentialsBuilder()
18 .fromFile("pdfservices-api-credentials.json")
19 .build();
20
21 // Setup input data for the document merge process.
22 JSONObject jsonDataForMerge = new JSONObject("{\"customerName\": \"Kane Miller\",\"customerVisits\": 100}");
23
24 // Create an ExecutionContext using credentials.
25 ExecutionContext executionContext = ExecutionContext.create(credentials);
26
27 // Create a new DocumentMergeOptions instance.
28 DocumentMergeOptions documentMergeOptions = new DocumentMergeOptions(jsonDataForMerge, OutputFormat.PDF);
29
30 // Create a new DocumentMergeOperation instance with the DocumentMergeOptions instance.
31 DocumentMergeOperation documentMergeOperation = DocumentMergeOperation.createNew(documentMergeOptions);
32
33 // Set the operation input document template from a source file.
34 FileRef documentTemplate = FileRef.createFromLocalFile("src/main/resources/documentMergeTemplate.docx");
35 documentMergeOperation.setInput(documentTemplate);
36
37 // Execute the operation.
38 FileRef result = documentMergeOperation.execute(executionContext);
39
40 // Save the result to the specified location.
41 result.saveAs("output/documentMergeOutput.pdf");
42
43 } catch (ServiceApiException | IOException | SdkException | ServiceUsageException ex) {
44 LOGGER.error("Exception encountered while executing operation", ex);
45 }
46 }
47 }
48

As a result of the Document Generation API, template tags are replaced with the input JSON data.

Document template with template tags being replaced by actual values

Generate PDF or Word document (with Fragments)#

The sample below shows the use of Fragments in the word template and generates the output document in the PDF format.

Copied to your clipboard
1// Get the samples from https://www.adobe.com/go/pdftoolsapi_java_samples
2// Run the sample:
3// mvn -f pom.xml exec:java -Dexec.mainClass=com.adobe.pdfservices.operation.samples.documentmerge.MergeDocumentToPDFWithFragments
4 package com.adobe.pdfservices.operation.samples.documentmerge;
5
6 public class MergeDocumentToPDFWithFragments {
7
8 // Initialize the logger.
9 private static final Logger LOGGER = LoggerFactory.getLogger(MergeDocumentToDOCXWithFragments.class);
10
11 public static void main(String[] args) {
12
13 try {
14
15 // Initial setup, create credentials instance.
16 Credentials credentials = Credentials.serviceAccountCredentialsBuilder()
17 .fromFile("pdfservices-api-credentials.json")
18 .build();
19
20 // Setup input data for the document merge process
21 JSONObject jsonDataForMerge = new JSONObject("{\n" +
22 "\t\"customerName\": \"Kane Miller\",\n" +
23 "\t\"customerVisits\": 100,\n" +
24 "\t\"itemsBought\": [{\n" +
25 "\t\t\t\"description\": \"Sprays\",\n" +
26 "\t\t\t\"quantity\": 50,\n" +
27 "\t\t\t\"amount\": 100\n" +
28 "\t\t},\n" +
29 "\t\t{\n" +
30 "\t\t\t\"description\": \"Chemicals\",\n" +
31 "\t\t\t\"quantity\": 100,\n" +
32 "\t\t\t\"amount\": 200\n" +
33 "\t\t}\n" +
34 "\t],\n" +
35 "\t\"totalAmount\": 300,\n" +
36 "\t\"previousBalance\": 50,\n" +
37 "\t\"lastThreeBillings\": [\n" +
38 "\t\t100, 200, 300\n" +
39 "\t],\n" +
40 "\t\"photograph\": \"\"\n" +
41 "}");
42
43 //Create fragments from fragment JSON data
44 JSONObject fragment1 = new JSONObject("{\n" +
45 " \"orderDetails\":\"<b>Quantity</b>:{{quantity}}, <b>Description</b>:{{description}}, <b>Amount</b>:{{amount}}\"\n" +
46 "}");
47 JSONObject fragment2 = new JSONObject("{\n" +
48 " \"customerDetails\":\"{{customerName}}, Visits: {{customerVisits}}\"\n" +
49 "}");
50
51 //Create Fragments List
52 Fragments fragments = new Fragments();
53
54 //Add all fragments to the created fragments list
55 fragments.addFragment(fragment1);
56 fragments.addFragment(fragment2);
57
58 // Create an ExecutionContext using credentials.
59 ExecutionContext executionContext = ExecutionContext.create(credentials);
60
61 // Create a new DocumentMergeOptions instance
62 DocumentMergeOptions documentMergeOptions = new DocumentMergeOptions(jsonDataForMerge, OutputFormat.PDF, fragments);
63
64 // Create a new DocumentMergeOperation instance with the DocumentMergeOptions instance
65 DocumentMergeOperation documentMergeOperation = DocumentMergeOperation.createNew(documentMergeOptions);
66
67 // Set the operation input document template from a source file.
68 FileRef documentTemplate = FileRef.createFromLocalFile("src/main/resources/documentMergeFragmentsTemplate.docx");
69 documentMergeOperation.setInput(documentTemplate);
70
71 // Execute the operation
72 FileRef result = documentMergeOperation.execute(executionContext);
73
74 // Save the result to the specified location.
75 result.saveAs("output/documentMergeFragmentsOutput.pdf");
76
77 } catch (ServiceApiException | IOException | SdkException | ServiceUsageException ex) {
78 LOGGER.error("Exception encountered while executing operation", ex);
79 }
80 }
81 }

API Limitations#

The Document Generation API has the following limitations:

  • Document template size limit: Maximum supported document template file size is 100MB.
  • Input JSON size limit: Maximum supported input JSON size is 10MB.
  • Privacy
  • Terms of Use
  • Do not sell my personal information
  • AdChoices
Copyright © 2022 Adobe. All rights reserved.