How to duplicate a PDF page using Java

Table of contents

    Duplicating PDF pages enables powerful document workflows — apply different watermarks to the same page for multiple recipients, create backups before batch processing, or build complex multipage documents from templates. This tutorial shows you how to duplicate specific PDF pages programmatically using Java and Nutrient DWS Processor API.
    How to duplicate a PDF page using Java
    Summary

    Duplicate PDF pages using our duplicate PDF page Java API. Create a free account, get API credentials, and implement page duplication using OkHttp and JSON libraries. Combine with 30+ other API tools for watermarking, merging, and flattening.

    Duplicate specific PDF pages using our duplicate PDF page Java API. Start with 200 free credits — no payment required. Different operations consume different credit amounts, so the number of PDF documents you can generate will vary. Create a free account(opens in a new tab) to get your API key.

    Why duplicate PDF pages?

    Duplicating PDF pages is important for document workflows that require processing the same content differently. Common use cases include:

    • Multi-recipient workflows — Apply different watermarks or annotations to the same page for different recipients, e.g. watermarked versions for clients and clean versions for internal use.
    • Backup and versioning — Create page-level backups before performing destructive operations like flattening or redaction, preserving the original state.
    • Template-based generation — Build complex documents by duplicating template pages and customizing each copy with recipient-specific data.
    • Testing and validation — Duplicate pages to test different processing operations (compression, OCR, conversion) while keeping the original intact.
    • Workflow automation — Process batches of pages programmatically as part of your backend infrastructure, duplicating pages at specific positions for assembly workflows.

    The duplicate PDF page API automates this process in your workflow.

    Nutrient DWS Processor API

    Duplicating a PDF page is just one of our 30+ PDF API tools. You can combine our duplication tool with other tools to create complex document processing workflows, such as:

    Once you create your account, you can access all our PDF API tools.

    Step 1 — Creating a free account on Nutrient

    Go to our website(opens in a new tab) to create your free account.

    Free account at Nutrient DWS Processor API

    After creating your account, you’ll see your plan overview.

    You start with 200 credits and can access all PDF API tools.

    Step 2 — Obtaining the API key

    After verifying your email, get your API key from the dashboard. Click API keys in the left menu to see your keys.

    Duplicate PDF Page Java API Key

    Copy the Live API key — you’ll need it for the duplicate PDF page Java API.

    Step 3 — Setting up folders and files

    This tutorial uses IntelliJ IDEA. Create a new project called duplicate_pdf. Select Java as the language, Gradle as the build system, and Groovy as the Gradle DSL.

    Duplicate PDF Page Java API Key

    Create a new directory in your project. Right-click your project’s name and select New > Directory. Choose src/main/java. Create a class file called Processor.java inside the src/main/java folder, and create two folders called input_documents and processed_documents in the root folder.

    Put your PDF file in the input_documents folder.

    Your folder structure:

    duplicate_pdf
    ├── input_documents
    | └── document.pdf
    ├── processed_documents
    ├── src
    | └── main
    | └── java
    | └── processor.java

    Step 4 — Installing dependencies

    Install two libraries:

    • OkHttp — Makes API requests
    • JSON — Parses JSON payloads

    Open the build.gradle file and add the following dependencies to your project:

    dependencies {
    implementation 'com.squareup.okhttp3:okhttp:4.9.2'
    implementation 'org.json:json:20210307'
    }

    Click the Add Configuration button in IntelliJ IDEA to open the dropdown menu.

    Duplicate PDF Page Java API **Add Configuration**

    Select Application from the menu.

    Duplicate PDFs Page Java API Application

    Fill in the required details. Most fields are prefilled. Select java 18 in the module field. Then add -cp duplicate_pdf.main as the main class and com.example.pspdfkit.Processor in the field below.

    Duplicate PDF Page Java API

    Click Apply to save settings.

    Step 5 — Writing the code

    Open processor.java and paste this code:

    package com.example.pspdfkit;
    import java.io.File;
    import java.io.IOException;
    import java.nio.file.FileSystems;
    import java.nio.file.Files;
    import java.nio.file.StandardCopyOption;
    import org.json.JSONArray;
    import org.json.JSONObject;
    import okhttp3.MediaType;
    import okhttp3.MultipartBody;
    import okhttp3.OkHttpClient;
    import okhttp3.Request;
    import okhttp3.RequestBody;
    import okhttp3.Response;
    public final class Processor {
    public static void main(final String[] args) throws IOException {
    final RequestBody body = new MultipartBody.Builder()
    .setType(MultipartBody.FORM)
    .addFormDataPart(
    "document",
    "document.pdf",
    RequestBody.create(
    MediaType.parse("application/pdf"),
    new File("input_documents/document.pdf")
    )
    )
    .addFormDataPart(
    "instructions",
    new JSONObject()
    .put("parts", new JSONArray()
    .put(new JSONObject()
    .put("file", "document")
    .put("pages", new JSONObject()
    .put("start", 0)
    .put("end", 0)
    )
    )
    .put(new JSONObject()
    .put("file", "document")
    )
    .put(new JSONObject()
    .put("file", "document")
    .put("pages", new JSONObject()
    .put("start", -1)
    .put("end", -1)
    )
    )
    ).toString()
    )
    .build();
    final Request request = new Request.Builder()
    .url("https://api.nutrient.io/build")
    .method("POST", body)
    .addHeader("Authorization", "Bearer YOUR API KEY HERE")
    .build();
    final OkHttpClient client = new OkHttpClient()
    .newBuilder()
    .build();
    final Response response = client.newCall(request).execute();
    if (response.isSuccessful()) {
    Files.copy(
    response.body().byteStream(),
    FileSystems.getDefault().getPath("processed_documents/result.pdf"),
    StandardCopyOption.REPLACE_EXISTING
    );
    } else {
    // Handle the error.
    throw new IOException(response.body().string());
    }
    }
    }

    Make sure to replace YOUR API KEY HERE with your API key.

    Code explanation

    The code imports required packages and creates a processor class. The main function creates a request body containing instructions to duplicate the first and last PDF pages.

    The code calls the API using OkHttpClient and checks the response status. If successful, it saves result.pdf to the processed_documents folder.

    Output

    To execute the code, click the Run button (green arrow) next to the Processor field.

    Duplicate PDF Page Java API

    After execution, the new PDF with duplicated pages appears in the processed_documents folder.

    Additional resources

    Explore more ways to work with Nutrient API:

    Conclusion

    You now know how to duplicate PDF pages in Java using our duplicate PDF page API.

    Integrate these functions into your existing applications. The same API token works for other operations like merging documents, adding watermarks, and more. Sign up(opens in a new tab) for a free trial.

    FAQ

    How does page indexing work in Nutrient DWS Processor API?

    The API uses zero-based indexing, where page 0 is the first page. You can use negative indexing: -1 refers to the last page, -2 to the second-to-last page. The code example duplicates the first page (index 0) and last page (index -1).

    Can I duplicate pages from multiple source PDFs in one API call?

    Yes. Upload multiple files with different names (like 'document1', 'document2') and reference them in the parts array. Each part can specify which source document and which pages to include, allowing complex multidocument assembly workflows.

    How many credits does the duplicate PDF API consume?

    Each duplication operation consumes 1 credit, regardless of the number of pages duplicated or file size. The free account includes 200 credits, enabling you to process up to 200 PDF duplication requests.

    Can I combine duplication with other API operations?

    Yes. Nutrient DWS Processor API supports chaining multiple operations in a single request. Use the actions array to duplicate pages, and then apply operations like watermarking, flattening, or OCR to the resulting document.

    How do I specify page ranges for duplication?

    Use the pages object with start and end properties in the JSONObject. For example, .put("start", 0).put("end", 2) duplicates pages 0, 1, and 2. Omit the pages object to include all pages from the source document.

    What Java version is required for this code?

    This code works with Java 11 and higher. It requires the OkHttp and JSON libraries, which are added as Gradle dependencies. The tutorial uses Java 18, but any version from Java 11 onward will work.

    Can I use Maven instead of Gradle?

    Yes, you can use Maven instead of Gradle. Add the OkHttp and JSON dependencies to your pom.xml file with the appropriate Maven dependency syntax. The rest of the code remains the same.

    Jonathan D. Rhyne

    Jonathan D. Rhyne

    Co-Founder and CEO

    Jonathan joined PSPDFKit in 2014. As Co-founder and CEO, Jonathan defines the company’s vision and strategic goals, bolsters the team culture, and steers product direction. When he’s not working, he enjoys being a dad, photography, and soccer.

    Explore related topics

    FREE TRIAL Ready to get started?