Biblioteca Java para edição de PDF (tutorial e exemplo de código)
A biblioteca Java PDF da IronPDF é uma ferramenta poderosa para editar e criar documentos PDF em aplicações Java. Simplifica uma ampla gama de funções de edição de PDF, como adicionar assinaturas, rodapés HTML, marcas d'água e anotações.
Com o IronPDF, você pode criar arquivos PDF programaticamente com facilidade, depurar seu código de forma eficiente e implantar seus projetos em diversas plataformas ou ambientes compatíveis.
O principal objetivo da maioria das bibliotecas Java para PDF é a geração dinâmica de arquivos PDF. O IronPDF se destaca nessa tarefa, oferecendo uma variedade de recursos para atender às suas necessidades.
Este artigo explora algumas das funcionalidades mais importantes do IronPDF, fornecendo exemplos de código e explicações. Ao final, você terá um sólido conhecimento de como usar o IronPDF para editar PDFs em Java — perfeito para suas necessidades de edição de PDFs.
Como usar a biblioteca Java PDF Editor
- Instale a biblioteca Java para editar PDFs.
- Adicione, copie e exclua PDFs com os métodos `prependPdf` , `copyPages` e `removePages`
- Mesclar PDF com o método `merge` e dividir PDF usando o método `copyPages`
- Crie um novo PDF com tamanho de papel personalizado.
- editar metadados do PDF
Editar estrutura do documento
Manipulando documentos PDF
O IronPDF facilita o gerenciamento de PDFs, permitindo adicionar PDFs em índices específicos, copiar páginas em sequência ou individualmente e excluir páginas com facilidade. Todas essas tarefas são executadas perfeitamente em segundo plano.
Adicionar páginas
import java.io.IOException;
import java.nio.file.Paths;
import com.ironsoftware.ironpdf.PdfDocument;
public class AddPagesExample {
public static void main(String[] args) {
try {
PdfDocument PDF = PdfDocument.fromFile(Paths.get("assets/sample.pdf"));
PdfDocument coverPagePdf = PdfDocument.renderHtmlAsPdf("<h1>Cover Page</h1><hr>");
PDF.prependPdf(coverPagePdf);
PDF.saveAs(Paths.get("report_with_cover.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
import java.io.IOException;
import java.nio.file.Paths;
import com.ironsoftware.ironpdf.PdfDocument;
public class AddPagesExample {
public static void main(String[] args) {
try {
PdfDocument PDF = PdfDocument.fromFile(Paths.get("assets/sample.pdf"));
PdfDocument coverPagePdf = PdfDocument.renderHtmlAsPdf("<h1>Cover Page</h1><hr>");
PDF.prependPdf(coverPagePdf);
PDF.saveAs(Paths.get("report_with_cover.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
Copiar páginas
import java.io.IOException;
import java.nio.file.Paths;
import com.ironsoftware.ironpdf.PdfDocument;
public class CopyPagesExample {
public static void main(String[] args) {
try {
PdfDocument PDF = PdfDocument.fromFile(Paths.get("assets/sample.pdf"));
PDF.copyPages(0, 1).saveAs("report_highlight.pdf");
} catch (IOException e) {
e.printStackTrace();
}
}
}
import java.io.IOException;
import java.nio.file.Paths;
import com.ironsoftware.ironpdf.PdfDocument;
public class CopyPagesExample {
public static void main(String[] args) {
try {
PdfDocument PDF = PdfDocument.fromFile(Paths.get("assets/sample.pdf"));
PDF.copyPages(0, 1).saveAs("report_highlight.pdf");
} catch (IOException e) {
e.printStackTrace();
}
}
}
Excluir páginas
import java.io.IOException;
import java.nio.file.Paths;
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.edit.PageSelection;
public class DeletePagesExample {
public static void main(String[] args) {
try {
PdfDocument PDF = PdfDocument.fromFile(Paths.get("assets/sample.pdf"));
PDF.removePages(PageSelection.lastPage()).saveAs(Paths.get("assets/lastPageRemove.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
import java.io.IOException;
import java.nio.file.Paths;
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.edit.PageSelection;
public class DeletePagesExample {
public static void main(String[] args) {
try {
PdfDocument PDF = PdfDocument.fromFile(Paths.get("assets/sample.pdf"));
PDF.removePages(PageSelection.lastPage()).saveAs(Paths.get("assets/lastPageRemove.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
Anexe uma página de rosto.
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.headerfooter.HeaderFooterOptions;
import com.ironsoftware.ironpdf.headerfooter.TextHeaderFooter;
import java.io.IOException;
import java.nio.file.Paths;
public class AttachCoverPageExample {
public static void main(String[] args) {
// Create a Sample Cover Page using RenderHtmlAsPdf
PdfDocument coverPage = PdfDocument.renderHtmlAsPdf("<h1>This is a Cover Page</h1>");
PdfDocument webpage = PdfDocument.renderUrlAsPdf("https://ironpdf.com");
// Set the page number of the PDF document to be created to 2.
HeaderFooterOptions headerFooterOptions = new HeaderFooterOptions();
headerFooterOptions.setFirstPageNumber(1);
TextHeaderFooter footer = new TextHeaderFooter();
footer.setLeftText("");
footer.setCenterText("Page {page}");
footer.setRightText("");
webpage.addTextFooter(footer, headerFooterOptions);
// Convert a web page's content to a PDF document.
// Merge the cover page with the web page and save the new PDF to the filesystem.
try {
PdfDocument.merge(coverPage, webpage).saveAs(Paths.get("assets/cover_page_pdf.pdf"));
} catch (IOException e) {
throw new RuntimeException(e);
}
}
}
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.headerfooter.HeaderFooterOptions;
import com.ironsoftware.ironpdf.headerfooter.TextHeaderFooter;
import java.io.IOException;
import java.nio.file.Paths;
public class AttachCoverPageExample {
public static void main(String[] args) {
// Create a Sample Cover Page using RenderHtmlAsPdf
PdfDocument coverPage = PdfDocument.renderHtmlAsPdf("<h1>This is a Cover Page</h1>");
PdfDocument webpage = PdfDocument.renderUrlAsPdf("https://ironpdf.com");
// Set the page number of the PDF document to be created to 2.
HeaderFooterOptions headerFooterOptions = new HeaderFooterOptions();
headerFooterOptions.setFirstPageNumber(1);
TextHeaderFooter footer = new TextHeaderFooter();
footer.setLeftText("");
footer.setCenterText("Page {page}");
footer.setRightText("");
webpage.addTextFooter(footer, headerFooterOptions);
// Convert a web page's content to a PDF document.
// Merge the cover page with the web page and save the new PDF to the filesystem.
try {
PdfDocument.merge(coverPage, webpage).saveAs(Paths.get("assets/cover_page_pdf.pdf"));
} catch (IOException e) {
throw new RuntimeException(e);
}
}
}
Saiba mais sobre como anexar uma página de rosto em documentos PDF no IronPDF .
Unir e dividir PDFs
O IronPDF Java simplifica o processo de mesclar vários PDFs em um só ou dividir um PDF existente usando sua API amigável.
Unir vários documentos PDF existentes em um único documento PDF.
import com.ironsoftware.ironpdf.PdfDocument;
import java.io.IOException;
import java.nio.file.Paths;
public class MergePdfsExample {
public static void main(String[] args) {
String htmlA = "<p> [PDF_A] </p>" +
"<p> [PDF_A] 1st Page </p>" +
"<div style='page-break-after: always;'></div>" +
"<p> [PDF_A] 2nd Page</p>";
String htmlB = "<p> [PDF_B] </p>" +
"<p> [PDF_B] 1st Page </p>" +
"<div style='page-break-after: always;'></div>" +
"<p> [PDF_B] 2nd Page</p>";
PdfDocument pdfA = PdfDocument.renderHtmlAsPdf(htmlA);
PdfDocument pdfB = PdfDocument.renderHtmlAsPdf(htmlB);
PdfDocument merged = PdfDocument.merge(pdfA, pdfB);
merged.saveAs(Paths.get("assets/merged.pdf"));
}
}
import com.ironsoftware.ironpdf.PdfDocument;
import java.io.IOException;
import java.nio.file.Paths;
public class MergePdfsExample {
public static void main(String[] args) {
String htmlA = "<p> [PDF_A] </p>" +
"<p> [PDF_A] 1st Page </p>" +
"<div style='page-break-after: always;'></div>" +
"<p> [PDF_A] 2nd Page</p>";
String htmlB = "<p> [PDF_B] </p>" +
"<p> [PDF_B] 1st Page </p>" +
"<div style='page-break-after: always;'></div>" +
"<p> [PDF_B] 2nd Page</p>";
PdfDocument pdfA = PdfDocument.renderHtmlAsPdf(htmlA);
PdfDocument pdfB = PdfDocument.renderHtmlAsPdf(htmlB);
PdfDocument merged = PdfDocument.merge(pdfA, pdfB);
merged.saveAs(Paths.get("assets/merged.pdf"));
}
}
Dividir um PDF e extrair páginas
import com.ironsoftware.ironpdf.PdfDocument;
import java.io.IOException;
import java.nio.file.Paths;
public class SplitPdfExample {
public static void main(String[] args) {
try {
PdfDocument PDF = PdfDocument.fromFile(Paths.get("assets/sample.pdf"));
PdfDocument copied = PDF.copyPage(0);
copied.saveAs("assets/Split.pdf");
} catch (IOException e) {
e.printStackTrace();
}
}
}
import com.ironsoftware.ironpdf.PdfDocument;
import java.io.IOException;
import java.nio.file.Paths;
public class SplitPdfExample {
public static void main(String[] args) {
try {
PdfDocument PDF = PdfDocument.fromFile(Paths.get("assets/sample.pdf"));
PdfDocument copied = PDF.copyPage(0);
copied.saveAs("assets/Split.pdf");
} catch (IOException e) {
e.printStackTrace();
}
}
}
Defina o tamanho personalizado dos documentos PDF.
O IronPDF permite que os desenvolvedores criem documentos PDF com dimensões não padronizadas, além do tamanho A4 convencional (8½ por 11 polegadas ou 21,59 por 27,94 cm).
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.render.ChromePdfRenderOptions;
import com.ironsoftware.ironpdf.render.PaperSize;
import java.io.IOException;
import java.nio.file.Paths;
public class CustomSizeExample {
public static void main(String[] args) {
String html = "<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit.</p>";
ChromePdfRenderOptions renderOptions = new ChromePdfRenderOptions();
renderOptions.setPaperSize(PaperSize.Custom);
/*
* Setting page sizes using different measuring units:
* 1. setCustomPaperWidth( width ) / setCustomPaperHeight( height ): for inches
* 2. setCustomPaperSizeInCentimeters( width, height ): for centimeters.
* 3. setCustomPaperSizeInMillimeters( width, height ): for millimeters
* 4. setCustomPaperSizeInPixelsOrPoints( width, height ): for pixels/points
* */
renderOptions.setCustomPaperSizeInCentimeters(13.97, 13.97);
PdfDocument.renderHtmlAsPdf(html, renderOptions).saveAs(Paths.get("assets/CustomPaperSize.pdf"));
}
}
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.render.ChromePdfRenderOptions;
import com.ironsoftware.ironpdf.render.PaperSize;
import java.io.IOException;
import java.nio.file.Paths;
public class CustomSizeExample {
public static void main(String[] args) {
String html = "<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit.</p>";
ChromePdfRenderOptions renderOptions = new ChromePdfRenderOptions();
renderOptions.setPaperSize(PaperSize.Custom);
/*
* Setting page sizes using different measuring units:
* 1. setCustomPaperWidth( width ) / setCustomPaperHeight( height ): for inches
* 2. setCustomPaperSizeInCentimeters( width, height ): for centimeters.
* 3. setCustomPaperSizeInMillimeters( width, height ): for millimeters
* 4. setCustomPaperSizeInPixelsOrPoints( width, height ): for pixels/points
* */
renderOptions.setCustomPaperSizeInCentimeters(13.97, 13.97);
PdfDocument.renderHtmlAsPdf(html, renderOptions).saveAs(Paths.get("assets/CustomPaperSize.pdf"));
}
}
Aqui estão mais algumas dicas sobre como personalizar o tamanho dos PDFs no IronPDF .
Definir orientação do PDF
O IronPDF for Java permite modificar a orientação da página tanto em PDFs novos quanto em PDFs já existentes. Por padrão, os novos PDFs criados com o IronPDF são configurados com orientação retrato, mas os desenvolvedores podem alterá-la usando uma instância de ChromePdfRenderOptions ao converter conteúdo (como HTML, RTFs e URLs) em PDFs.
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.edit.PageSelection;
import com.ironsoftware.ironpdf.page.PageRotation;
import com.ironsoftware.ironpdf.render.*;
import java.io.IOException;
import java.nio.file.Paths;
public class SetOrientationExample {
public static void main(String[] args) {
// Load an existing PDF
PdfDocument existingPdf = PdfDocument.fromFile("assets/sample.pdf");
// Get the orientation of the first page of the existing PDF document.
PageRotation firstPageRotation = existingPdf.getPagesInfo().get(0).getPageRotation();
System.out.println(firstPageRotation);
// Rotate the first page of the document only 90 degrees clockwise.
existingPdf.rotatePage(PageRotation.CLOCKWISE_90, PageSelection.firstPage());
// Rotate all pages of the document clockwise.
existingPdf.rotateAllPages(PageRotation.CLOCKWISE_270);
existingPdf.saveAs(Paths.get("assets/ExistingPdfRotated.pdf"));
}
}
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.edit.PageSelection;
import com.ironsoftware.ironpdf.page.PageRotation;
import com.ironsoftware.ironpdf.render.*;
import java.io.IOException;
import java.nio.file.Paths;
public class SetOrientationExample {
public static void main(String[] args) {
// Load an existing PDF
PdfDocument existingPdf = PdfDocument.fromFile("assets/sample.pdf");
// Get the orientation of the first page of the existing PDF document.
PageRotation firstPageRotation = existingPdf.getPagesInfo().get(0).getPageRotation();
System.out.println(firstPageRotation);
// Rotate the first page of the document only 90 degrees clockwise.
existingPdf.rotatePage(PageRotation.CLOCKWISE_90, PageSelection.firstPage());
// Rotate all pages of the document clockwise.
existingPdf.rotateAllPages(PageRotation.CLOCKWISE_270);
existingPdf.saveAs(Paths.get("assets/ExistingPdfRotated.pdf"));
}
}
Para obter mais informações, visite o tutorial de orientação de PDFs no site da IronPDF .
Definir margens personalizadas para PDFs
O IronPDF cria novos PDFs com uma margem padrão de 25 mm em todos os lados (superior, inferior, esquerdo e direito). No entanto, os desenvolvedores podem personalizar cada margem com medidas específicas usando o IronPDF.
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.render.ChromePdfRenderOptions;
import java.io.IOException;
import java.nio.file.Paths;
public class CustomMarginsExample {
public static void main(String[] args) {
// Set Margins (in millimeters)
ChromePdfRenderOptions renderOptions = new ChromePdfRenderOptions();
renderOptions.setMarginTop(40);
renderOptions.setMarginLeft(20);
renderOptions.setMarginRight(20);
renderOptions.setMarginBottom(40);
try {
PdfDocument.renderHtmlFileAsPdf("assets/wikipedia.html", renderOptions).saveAs(Paths.get("assets/MyContent.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.render.ChromePdfRenderOptions;
import java.io.IOException;
import java.nio.file.Paths;
public class CustomMarginsExample {
public static void main(String[] args) {
// Set Margins (in millimeters)
ChromePdfRenderOptions renderOptions = new ChromePdfRenderOptions();
renderOptions.setMarginTop(40);
renderOptions.setMarginLeft(20);
renderOptions.setMarginRight(20);
renderOptions.setMarginBottom(40);
try {
PdfDocument.renderHtmlFileAsPdf("assets/wikipedia.html", renderOptions).saveAs(Paths.get("assets/MyContent.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
Visite o site da IronPDF para saber mais sobre como definir margens personalizadas para documentos PDF .
Converter documentos PDF em imagens
O IronPDF pode exportar páginas de um arquivo PDF carregado, conteúdo de origem convertido ou um PDF modificado com cabeçalhos, rodapés, margens, etc., em imagens que podem ser salvas em um sistema de arquivos, armazenadas em um banco de dados ou transmitidas por redes.
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.edit.PageSelection;
import com.ironsoftware.ironpdf.image.ToImageOptions;
import javax.imageio.ImageIO;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;
import java.nio.file.Paths;
import java.util.List;
public class ConvertPdfToImagesExample {
public static void main(String[] args) {
try {
PdfDocument pdf = PdfDocument.fromFile(Paths.get("assets/composite.pdf"));
// Extract all the pages from the PDF file.
List<BufferedImage> extractedImages = pdf.toBufferedImages();
// With the ToImageOptions object, specify maximum image dimensions for each
// extracted image, as well as their DPI
ToImageOptions rasterOptions = new ToImageOptions();
rasterOptions.setImageMaxHeight(100);
rasterOptions.setImageMaxWidth(100);
// Call the toBufferedImage method along with a PageSelection object to choose the pages from which to
// extract the images
//
// Available PageSelection methods include: allPages, lastPage, firstPage, singlePage(int pageIndex),
// and pageRange(int startingPage, int endingPage)
List<BufferedImage> sizedExtractedImages = pdf.toBufferedImages(rasterOptions, PageSelection.allPages());
// Save all the extracted images to a file location
int i = 1;
for (BufferedImage extractedImage : sizedExtractedImages) {
String fileName = "assets/images/" + i++ + ".png";
ImageIO.write(extractedImage, "PNG", new File(fileName));
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.edit.PageSelection;
import com.ironsoftware.ironpdf.image.ToImageOptions;
import javax.imageio.ImageIO;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;
import java.nio.file.Paths;
import java.util.List;
public class ConvertPdfToImagesExample {
public static void main(String[] args) {
try {
PdfDocument pdf = PdfDocument.fromFile(Paths.get("assets/composite.pdf"));
// Extract all the pages from the PDF file.
List<BufferedImage> extractedImages = pdf.toBufferedImages();
// With the ToImageOptions object, specify maximum image dimensions for each
// extracted image, as well as their DPI
ToImageOptions rasterOptions = new ToImageOptions();
rasterOptions.setImageMaxHeight(100);
rasterOptions.setImageMaxWidth(100);
// Call the toBufferedImage method along with a PageSelection object to choose the pages from which to
// extract the images
//
// Available PageSelection methods include: allPages, lastPage, firstPage, singlePage(int pageIndex),
// and pageRange(int startingPage, int endingPage)
List<BufferedImage> sizedExtractedImages = pdf.toBufferedImages(rasterOptions, PageSelection.allPages());
// Save all the extracted images to a file location
int i = 1;
for (BufferedImage extractedImage : sizedExtractedImages) {
String fileName = "assets/images/" + i++ + ".png";
ImageIO.write(extractedImage, "PNG", new File(fileName));
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
Adicionar plano de fundo e primeiro plano
IronPDF fornece métodos addBackgroundPdf e addForegroundPdf para adicionar um elemento de fundo ou primeiro plano específico aos PDFs . Esses métodos permitem que os desenvolvedores incorporem conteúdo de um PDF como plano de fundo ou primeiro plano de outro PDF, tornando eficiente a geração de coleções de PDFs com base em um modelo de design comum.
Adicionar PDF como plano de fundo
import com.ironsoftware.ironpdf.PdfDocument;
import java.io.IOException;
import java.nio.file.Paths;
public class AddBackgroundExample {
public static void main(String[] args) {
try {
// Load background PDFs from the filesystem (or create them programmatically)
PdfDocument backgroundPdf = PdfDocument.fromFile(Paths.get("assets/MyBackground.pdf"));
// Render content (HTML, URL, etc) as a PDF Document
PdfDocument pdf = PdfDocument.renderUrlAsPdf("https://ironpdf.com");
// Add the background PDFs to the newly-rendered document.
pdf.addBackgroundPdf(backgroundPdf);
pdf.saveAs(Paths.get("assets/BackgroundPdf.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
import com.ironsoftware.ironpdf.PdfDocument;
import java.io.IOException;
import java.nio.file.Paths;
public class AddBackgroundExample {
public static void main(String[] args) {
try {
// Load background PDFs from the filesystem (or create them programmatically)
PdfDocument backgroundPdf = PdfDocument.fromFile(Paths.get("assets/MyBackground.pdf"));
// Render content (HTML, URL, etc) as a PDF Document
PdfDocument pdf = PdfDocument.renderUrlAsPdf("https://ironpdf.com");
// Add the background PDFs to the newly-rendered document.
pdf.addBackgroundPdf(backgroundPdf);
pdf.saveAs(Paths.get("assets/BackgroundPdf.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
Adicionar PDF como primeiro plano
import com.ironsoftware.ironpdf.PdfDocument;
import java.io.IOException;
import java.nio.file.Paths;
public class AddForegroundExample {
public static void main(String[] args) {
try {
PdfDocument foregroundPdf = PdfDocument.fromFile(Paths.get("assets/MyForeground.pdf"));
PdfDocument pdf = PdfDocument.renderUrlAsPdf("https://ironpdf.com");
pdf.addForegroundPdf(foregroundPdf);
pdf.saveAs(Paths.get("assets/BackgroundForegroundPdf.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
import com.ironsoftware.ironpdf.PdfDocument;
import java.io.IOException;
import java.nio.file.Paths;
public class AddForegroundExample {
public static void main(String[] args) {
try {
PdfDocument foregroundPdf = PdfDocument.fromFile(Paths.get("assets/MyForeground.pdf"));
PdfDocument pdf = PdfDocument.renderUrlAsPdf("https://ironpdf.com");
pdf.addForegroundPdf(foregroundPdf);
pdf.saveAs(Paths.get("assets/BackgroundForegroundPdf.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
Editar propriedades do documento
Adicionar e usar metadados de PDF
O IronPDF oferece a capacidade de modificar metadados e recursos de segurança de PDFs , incluindo tornar os PDFs somente leitura, não imprimíveis, protegidos por senha e criptografados. No IronPDF for Java, o MetadataManager pode acessar e editar os metadados de um PDF. A classe MetadataManager fornece acesso direto ao conteúdo dos metadados e permite que os desenvolvedores leiam e editem propriedades comuns de metadados por meio de getters e setters com os mesmos nomes.
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.metadata.MetadataManager;
import com.ironsoftware.ironpdf.security.PdfPrintSecurity;
import com.ironsoftware.ironpdf.security.SecurityOptions;
import com.ironsoftware.ironpdf.security.SecurityManager;
import java.io.IOException;
import java.nio.file.Paths;
import java.util.Date;
public class EditMetadataExample {
public static void main(String[] args) {
try {
// Open an encrypted file (or create a new one from HTML)
PdfDocument pdf = PdfDocument.fromFile(Paths.get("assets/encrypted.pdf"), "password");
// Edit file metadata
MetadataManager metadata = pdf.getMetadata();
metadata.setAuthor("Satoshi Nakamoto");
metadata.setKeywords("SEO, Friendly");
metadata.setModifiedDate(new Date().toString());
// Edit file security settings
// The code below makes the PDF read-only and disallows users to copy, paste, and print
SecurityOptions securityOptions = new SecurityOptions();
securityOptions.setAllowUserCopyPasteContent(false);
securityOptions.setAllowUserAnnotations(false);
securityOptions.setAllowUserPrinting(PdfPrintSecurity.FULL_PRINT_RIGHTS);
securityOptions.setAllowUserFormData(false);
securityOptions.setOwnerPassword("top-secret");
securityOptions.setUserPassword("sharable");
// Change or set the document encryption password
SecurityManager securityManager = pdf.getSecurity();
securityManager.removePasswordsAndEncryption();
securityManager.makePdfDocumentReadOnly("secret-key");
securityManager.setSecurityOptions(securityOptions);
pdf.saveAs(Paths.get("assets/secured.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.metadata.MetadataManager;
import com.ironsoftware.ironpdf.security.PdfPrintSecurity;
import com.ironsoftware.ironpdf.security.SecurityOptions;
import com.ironsoftware.ironpdf.security.SecurityManager;
import java.io.IOException;
import java.nio.file.Paths;
import java.util.Date;
public class EditMetadataExample {
public static void main(String[] args) {
try {
// Open an encrypted file (or create a new one from HTML)
PdfDocument pdf = PdfDocument.fromFile(Paths.get("assets/encrypted.pdf"), "password");
// Edit file metadata
MetadataManager metadata = pdf.getMetadata();
metadata.setAuthor("Satoshi Nakamoto");
metadata.setKeywords("SEO, Friendly");
metadata.setModifiedDate(new Date().toString());
// Edit file security settings
// The code below makes the PDF read-only and disallows users to copy, paste, and print
SecurityOptions securityOptions = new SecurityOptions();
securityOptions.setAllowUserCopyPasteContent(false);
securityOptions.setAllowUserAnnotations(false);
securityOptions.setAllowUserPrinting(PdfPrintSecurity.FULL_PRINT_RIGHTS);
securityOptions.setAllowUserFormData(false);
securityOptions.setOwnerPassword("top-secret");
securityOptions.setUserPassword("sharable");
// Change or set the document encryption password
SecurityManager securityManager = pdf.getSecurity();
securityManager.removePasswordsAndEncryption();
securityManager.makePdfDocumentReadOnly("secret-key");
securityManager.setSecurityOptions(securityOptions);
pdf.saveAs(Paths.get("assets/secured.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
Assinaturas digitais
O IronPDF for Java permite a assinatura segura de arquivos PDF novos ou existentes usando certificados digitais X509Certificate2 nos formatos .pfx ou .p12. Ao assinar digitalmente um PDF, sua autenticidade é garantida, impedindo alterações sem a devida validação por certificado. Isso aumenta a confiabilidade do documento.
Para gerar um certificado de assinatura gratuitamente, o Adobe Reader oferece instruções em seu tutorial de ID Digital .
import java.io.File;
import java.io.IOException;
import java.nio.file.Paths;
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.signature.Signature;
import com.ironsoftware.ironpdf.signature.SignatureManager;
public class DigitalSignatureExample {
public static void main(String[] args) {
try {
PdfDocument PDF = PdfDocument.fromFile(Paths.get("assets/sample.pdf"));
// Load the X509Certificate2 digitals certificates from .pfx or .p12 formats
File path = new File("assets/Ironpdf.pfx");
byte[] certificate = new byte[(int) path.length()];
// Sign PDF with a specific signature
Signature signature = new Signature(certificate, "1234");
SignatureManager manager = PDF.getSignature();
manager.signPdfWithSignature(signature);
PDF.saveAs(Paths.get("assets/signed_sample.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
import java.io.File;
import java.io.IOException;
import java.nio.file.Paths;
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.signature.Signature;
import com.ironsoftware.ironpdf.signature.SignatureManager;
public class DigitalSignatureExample {
public static void main(String[] args) {
try {
PdfDocument PDF = PdfDocument.fromFile(Paths.get("assets/sample.pdf"));
// Load the X509Certificate2 digitals certificates from .pfx or .p12 formats
File path = new File("assets/Ironpdf.pfx");
byte[] certificate = new byte[(int) path.length()];
// Sign PDF with a specific signature
Signature signature = new Signature(certificate, "1234");
SignatureManager manager = PDF.getSignature();
manager.signPdfWithSignature(signature);
PDF.saveAs(Paths.get("assets/signed_sample.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
Comprimir PDFs
O IronPDF reduz o tamanho do arquivo PDF com seu método compressImages na classe PdfDocument , facilitando a compressão de PDFs com imagens grandes. Essa otimização resulta em economias significativas de espaço de armazenamento e custos ao transmitir PDFs por e-mail e outros canais de comunicação.
import com.ironsoftware.ironpdf.PdfDocument;
import java.io.IOException;
import java.nio.file.Paths;
public class CompressPdfExample {
public static void main(String[] args) {
try {
PdfDocument pdf = PdfDocument.fromFile(Paths.get("assets/document.pdf"));
// Valid image compression values range from 1 to 100, where 100 represents 100% of the original image quality.
pdf.compressImages(60);
pdf.saveAs(Paths.get("assets/document_compressed.pdf"));
// The second, optional parameter can scale down the image resolution according to its visible size in the PDF document.
// Note that this may cause distortion with some image configurations.
pdf.compressImages(90, true);
pdf.saveAs(Paths.get("assets/document_scaled_compressed.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
import com.ironsoftware.ironpdf.PdfDocument;
import java.io.IOException;
import java.nio.file.Paths;
public class CompressPdfExample {
public static void main(String[] args) {
try {
PdfDocument pdf = PdfDocument.fromFile(Paths.get("assets/document.pdf"));
// Valid image compression values range from 1 to 100, where 100 represents 100% of the original image quality.
pdf.compressImages(60);
pdf.saveAs(Paths.get("assets/document_compressed.pdf"));
// The second, optional parameter can scale down the image resolution according to its visible size in the PDF document.
// Note that this may cause distortion with some image configurations.
pdf.compressImages(90, true);
pdf.saveAs(Paths.get("assets/document_scaled_compressed.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
Edição de conteúdo em PDF
Adicionar cabeçalhos e rodapés
O IronPDF permite adicionar cabeçalhos e rodapés HTML personalizados usando as classes ChromePdfRenderOptions e HtmlHeaderFooter . Ele também oferece suporte a cabeçalhos e rodapés de texto personalizados por meio da classe TextHeaderFooter , que permite especificar o texto para as regiões esquerda, direita ou central do cabeçalho/rodapé. Tags de modelo como {date}, {time} e {page} podem ser usadas com texto personalizado.
Cabeçalho e rodapé HTML
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.headerfooter.HtmlHeaderFooter;
import java.io.IOException;
import java.nio.file.Paths;
import java.util.ArrayList;
import java.util.List;
public class HtmlHeaderFooterExample {
public static void main(String[] args) {
try {
PdfDocument pdf = PdfDocument.renderUrlAsPdf("https://ironpdf.com");
// Build a footer using HTML
// Merge Fields are: {page} {total-pages} {url} {date} {time} {html-title} & {pdf-title}
HtmlHeaderFooter footer = new HtmlHeaderFooter();
footer.setMaxHeight(15); // millimeters
footer.setHtmlFragment("<center><i>{page} of {total-pages}</i></center>");
footer.setDrawDividerLine(true);
pdf.addHtmlFooter(footer);
List<PdfDocument> pdfs = new ArrayList<>();
// Build a header using an image asset
// Note the use of BaseUrl to set a relative path to the assets
HtmlHeaderFooter header = new HtmlHeaderFooter();
header.setMaxHeight(20); // millimeters
header.setHtmlFragment("<img src=\"logo.png\" />");
header.setBaseUrl("./assets/");
pdf.addHtmlHeader(header);
pdf.saveAs(Paths.get("assets/html_headers_footers.pdf"));
} catch (IOException e) {
throw new RuntimeException(e);
}
}
}
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.headerfooter.HtmlHeaderFooter;
import java.io.IOException;
import java.nio.file.Paths;
import java.util.ArrayList;
import java.util.List;
public class HtmlHeaderFooterExample {
public static void main(String[] args) {
try {
PdfDocument pdf = PdfDocument.renderUrlAsPdf("https://ironpdf.com");
// Build a footer using HTML
// Merge Fields are: {page} {total-pages} {url} {date} {time} {html-title} & {pdf-title}
HtmlHeaderFooter footer = new HtmlHeaderFooter();
footer.setMaxHeight(15); // millimeters
footer.setHtmlFragment("<center><i>{page} of {total-pages}</i></center>");
footer.setDrawDividerLine(true);
pdf.addHtmlFooter(footer);
List<PdfDocument> pdfs = new ArrayList<>();
// Build a header using an image asset
// Note the use of BaseUrl to set a relative path to the assets
HtmlHeaderFooter header = new HtmlHeaderFooter();
header.setMaxHeight(20); // millimeters
header.setHtmlFragment("<img src=\"logo.png\" />");
header.setBaseUrl("./assets/");
pdf.addHtmlHeader(header);
pdf.saveAs(Paths.get("assets/html_headers_footers.pdf"));
} catch (IOException e) {
throw new RuntimeException(e);
}
}
}
Cabeçalho e rodapé de texto
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.font.FontTypes;
import com.ironsoftware.ironpdf.headerfooter.TextHeaderFooter;
import com.ironsoftware.ironpdf.headerfooter.HeaderFooterOptions;
import java.io.IOException;
import java.nio.file.Paths;
public class TextHeaderFooterExample {
public static void main(String[] args) {
try {
// Initialize HeaderFooterOptions object.
HeaderFooterOptions options = new HeaderFooterOptions();
PdfDocument pdf = PdfDocument.renderUrlAsPdf("http://www.google.com");
// Add a header to every page easily
// Mergeable fields are:
// {page} {total-pages} {url} {date} {time} {html-title} & {pdf-title}
options.setFirstPageNumber(1); // use 2 if a coverpage will be appended
TextHeaderFooter textHeader = new TextHeaderFooter();
textHeader.setDrawDividerLine(true);
textHeader.setCenterText("{url}");
textHeader.setFont(FontTypes.getHelvetica());
textHeader.setFontSize(12);
pdf.addTextHeader(textHeader, options);
// Add a footer too
TextHeaderFooter textFooter = new TextHeaderFooter();
textFooter.setDrawDividerLine(true);
textFooter.setFont(FontTypes.getArial());
textFooter.setFontSize(10);
textFooter.setLeftText("{date} {time}");
textFooter.setRightText("{page} of {total-pages}");
pdf.addTextFooter(textFooter, options);
pdf.saveAs(Paths.get("assets/text_headers_footers.pdf"));
} catch (IOException e) {
System.out.println("Failed to save PDF");
throw new RuntimeException(e);
}
}
}
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.font.FontTypes;
import com.ironsoftware.ironpdf.headerfooter.TextHeaderFooter;
import com.ironsoftware.ironpdf.headerfooter.HeaderFooterOptions;
import java.io.IOException;
import java.nio.file.Paths;
public class TextHeaderFooterExample {
public static void main(String[] args) {
try {
// Initialize HeaderFooterOptions object.
HeaderFooterOptions options = new HeaderFooterOptions();
PdfDocument pdf = PdfDocument.renderUrlAsPdf("http://www.google.com");
// Add a header to every page easily
// Mergeable fields are:
// {page} {total-pages} {url} {date} {time} {html-title} & {pdf-title}
options.setFirstPageNumber(1); // use 2 if a coverpage will be appended
TextHeaderFooter textHeader = new TextHeaderFooter();
textHeader.setDrawDividerLine(true);
textHeader.setCenterText("{url}");
textHeader.setFont(FontTypes.getHelvetica());
textHeader.setFontSize(12);
pdf.addTextHeader(textHeader, options);
// Add a footer too
TextHeaderFooter textFooter = new TextHeaderFooter();
textFooter.setDrawDividerLine(true);
textFooter.setFont(FontTypes.getArial());
textFooter.setFontSize(10);
textFooter.setLeftText("{date} {time}");
textFooter.setRightText("{page} of {total-pages}");
pdf.addTextFooter(textFooter, options);
pdf.saveAs(Paths.get("assets/text_headers_footers.pdf"));
} catch (IOException e) {
System.out.println("Failed to save PDF");
throw new RuntimeException(e);
}
}
}
Favoritos
Com a classe BookmarkManager , os desenvolvedores podem criar uma estrutura hierárquica de marcadores em um PDF , permitindo que os usuários naveguem facilmente para diferentes seções. Para adicionar um novo marcador, use o método add, especificando o título e o número da página do marcador. Os favoritos podem ser aninhados para criar uma estrutura mais organizada.
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.bookmark.Bookmark;
import com.ironsoftware.ironpdf.bookmark.BookmarkManager;
import java.io.IOException;
import java.nio.file.Paths;
import java.util.List;
public class BookmarksExample {
public static void main(String[] args) {
try {
// Load an existing PDF from the file system (or create a new one from HTML)
PdfDocument pdf = PdfDocument.fromFile(Paths.get("assets/book.pdf"));
// Add top-level bookmarks to pages of the PDF using their page indices
BookmarkManager bookmarks = pdf.getBookmark();
bookmarks.addBookMarkAtEnd("Author's Note", 2);
bookmarks.addBookMarkAtEnd("Table of Contents", 3);
bookmarks.addBookMarkAtEnd("Summary", 10);
bookmarks.addBookMarkAtEnd("References", 12);
// Retrieve a reference to the Summary bookmark so that we can add a sublist of bookmarks to it.
List<Bookmark> bookmarkList = bookmarks.getBookmarks();
Bookmark bookmark = bookmarkList.get(2);
bookmark.addChildBookmark("Conclusion", 11);
// Save the PDF to the filesystem
pdf.saveAs(Paths.get("assets/bookmarked.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.bookmark.Bookmark;
import com.ironsoftware.ironpdf.bookmark.BookmarkManager;
import java.io.IOException;
import java.nio.file.Paths;
import java.util.List;
public class BookmarksExample {
public static void main(String[] args) {
try {
// Load an existing PDF from the file system (or create a new one from HTML)
PdfDocument pdf = PdfDocument.fromFile(Paths.get("assets/book.pdf"));
// Add top-level bookmarks to pages of the PDF using their page indices
BookmarkManager bookmarks = pdf.getBookmark();
bookmarks.addBookMarkAtEnd("Author's Note", 2);
bookmarks.addBookMarkAtEnd("Table of Contents", 3);
bookmarks.addBookMarkAtEnd("Summary", 10);
bookmarks.addBookMarkAtEnd("References", 12);
// Retrieve a reference to the Summary bookmark so that we can add a sublist of bookmarks to it.
List<Bookmark> bookmarkList = bookmarks.getBookmarks();
Bookmark bookmark = bookmarkList.get(2);
bookmark.addChildBookmark("Conclusion", 11);
// Save the PDF to the filesystem
pdf.saveAs(Paths.get("assets/bookmarked.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
Adicionar e editar anotações
O IronPDF pode adicionar anotações no estilo "notas adesivas" a páginas específicas de um PDF usando as classes AnnotationManager e AnnotationOptions . Crie anotações baseadas em texto fornecendo texto e coordenadas (x, y) ao construtor AnnotationOptions, em seguida, use o método addTextAnnotation do AnnotationManager para adicionar a anotação à página desejada.
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.annotation.AnnotationIcon;
import com.ironsoftware.ironpdf.annotation.AnnotationManager;
import com.ironsoftware.ironpdf.annotation.AnnotationOptions;
import java.io.IOException;
import java.nio.file.Paths;
public class AnnotationExample {
public static void main(String[] args) {
try {
// Create a new PDF or load an existing one from the filesystem
PdfDocument pdf = PdfDocument.fromFile(Paths.get("assets/example.pdf"));
// Create an annotation to be placed at a specific location on a page.
AnnotationOptions annotation = new AnnotationOptions(
"This is a major title", // Title of the annotation
"This is the long 'sticky note' comment content...", // Content of the annotation
150, // x-axis coordinate location
250 // y-axis coordinate location
);
annotation.setIcon(AnnotationIcon.HELP);
annotation.setOpacity(0.9);
annotation.setPrintable(false);
annotation.setHidden(false);
annotation.setOpen(true);
annotation.setReadonly(true);
annotation.setRotateable(true);
// Add the annotation to a specific page of the PDF
AnnotationManager annotationManager = pdf.getAnnotation();
annotationManager.addTextAnnotation(annotation, 0);
// Save the PDF with the modifications
pdf.saveAs(Paths.get("assets/annotated.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.annotation.AnnotationIcon;
import com.ironsoftware.ironpdf.annotation.AnnotationManager;
import com.ironsoftware.ironpdf.annotation.AnnotationOptions;
import java.io.IOException;
import java.nio.file.Paths;
public class AnnotationExample {
public static void main(String[] args) {
try {
// Create a new PDF or load an existing one from the filesystem
PdfDocument pdf = PdfDocument.fromFile(Paths.get("assets/example.pdf"));
// Create an annotation to be placed at a specific location on a page.
AnnotationOptions annotation = new AnnotationOptions(
"This is a major title", // Title of the annotation
"This is the long 'sticky note' comment content...", // Content of the annotation
150, // x-axis coordinate location
250 // y-axis coordinate location
);
annotation.setIcon(AnnotationIcon.HELP);
annotation.setOpacity(0.9);
annotation.setPrintable(false);
annotation.setHidden(false);
annotation.setOpen(true);
annotation.setReadonly(true);
annotation.setRotateable(true);
// Add the annotation to a specific page of the PDF
AnnotationManager annotationManager = pdf.getAnnotation();
annotationManager.addTextAnnotation(annotation, 0);
// Save the PDF with the modifications
pdf.saveAs(Paths.get("assets/annotated.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
Carimbo e marca d'água
O IronPDF for Java possui uma API poderosa que oferece amplas funcionalidades de carimbo e marca d'água. Graças à sua interface intuitiva, os desenvolvedores podem adicionar rapidamente imagens e carimbos HTML aos seus PDFs. Seja para adicionar o logotipo da sua empresa, um aviso de confidencialidade ou um identificador único, o IronPDF oferece a solução ideal, permitindo que você adicione carimbos aos seus PDFs com facilidade e profissionalismo.
Inserir texto em um PDF
import java.io.IOException;
import java.nio.file.Paths;
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.stamp.TextStamper;
import com.ironsoftware.ironpdf.stamp.VerticalAlignment;
public class StampTextExample {
public static void main(String[] args) {
try {
PdfDocument pdf = PdfDocument.fromFile(Paths.get("assets/sample.pdf"));
TextStamper stamper1 = new TextStamper();
stamper1.setText("Hello World! Stamp One Here!");
stamper1.setFontFamily("Bungee Spice");
stamper1.setUseGoogleFont(true);
stamper1.setFontSize(100);
stamper1.setBold(true);
stamper1.setItalic(false);
stamper1.setVerticalAlignment(VerticalAlignment.TOP);
pdf.applyStamp(stamper1);
pdf.saveAs(Paths.get("assets/stamped_sample.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
import java.io.IOException;
import java.nio.file.Paths;
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.stamp.TextStamper;
import com.ironsoftware.ironpdf.stamp.VerticalAlignment;
public class StampTextExample {
public static void main(String[] args) {
try {
PdfDocument pdf = PdfDocument.fromFile(Paths.get("assets/sample.pdf"));
TextStamper stamper1 = new TextStamper();
stamper1.setText("Hello World! Stamp One Here!");
stamper1.setFontFamily("Bungee Spice");
stamper1.setUseGoogleFont(true);
stamper1.setFontSize(100);
stamper1.setBold(true);
stamper1.setItalic(false);
stamper1.setVerticalAlignment(VerticalAlignment.TOP);
pdf.applyStamp(stamper1);
pdf.saveAs(Paths.get("assets/stamped_sample.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
Inserir uma imagem em um PDF
import java.io.IOException;
import java.nio.file.Paths;
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.edit.PageSelection;
import com.ironsoftware.ironpdf.stamp.ImageStamper;
public class StampImageExample {
public static void main(String[] args) {
try {
PdfDocument pdf = PdfDocument.fromFile(Paths.get("assets/sample.pdf"));
ImageStamper imageStamper = new ImageStamper(Paths.get("assets/logo.png"));
// Apply to every page, one page, or some pages
pdf.applyStamp(imageStamper);
pdf.applyStamp(imageStamper, PageSelection.singlePage(2));
pdf.applyStamp(imageStamper, PageSelection.pageRange(0, 2));
pdf.saveAs(Paths.get("assets/image_stamped_sample.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
import java.io.IOException;
import java.nio.file.Paths;
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.edit.PageSelection;
import com.ironsoftware.ironpdf.stamp.ImageStamper;
public class StampImageExample {
public static void main(String[] args) {
try {
PdfDocument pdf = PdfDocument.fromFile(Paths.get("assets/sample.pdf"));
ImageStamper imageStamper = new ImageStamper(Paths.get("assets/logo.png"));
// Apply to every page, one page, or some pages
pdf.applyStamp(imageStamper);
pdf.applyStamp(imageStamper, PageSelection.singlePage(2));
pdf.applyStamp(imageStamper, PageSelection.pageRange(0, 2));
pdf.saveAs(Paths.get("assets/image_stamped_sample.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
Inserir um código de barras em um PDF
import java.io.IOException;
import java.nio.file.Paths;
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.stamp.BarcodeEncoding;
import com.ironsoftware.ironpdf.stamp.BarcodeStamper;
import com.ironsoftware.ironpdf.stamp.HorizontalAlignment;
import com.ironsoftware.ironpdf.stamp.VerticalAlignment;
public class StampBarcodeExample {
public static void main(String[] args) {
try {
PdfDocument pdf = PdfDocument.fromFile(Paths.get("assets/sample.pdf"));
BarcodeStamper barcodeStamp = new BarcodeStamper("IronPDF", BarcodeEncoding.Code39);
barcodeStamp.setHorizontalAlignment(HorizontalAlignment.LEFT);
barcodeStamp.setVerticalAlignment(VerticalAlignment.BOTTOM);
pdf.applyStamp(barcodeStamp);
pdf.saveAs(Paths.get("assets/barcode_stamped_sample.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
import java.io.IOException;
import java.nio.file.Paths;
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.stamp.BarcodeEncoding;
import com.ironsoftware.ironpdf.stamp.BarcodeStamper;
import com.ironsoftware.ironpdf.stamp.HorizontalAlignment;
import com.ironsoftware.ironpdf.stamp.VerticalAlignment;
public class StampBarcodeExample {
public static void main(String[] args) {
try {
PdfDocument pdf = PdfDocument.fromFile(Paths.get("assets/sample.pdf"));
BarcodeStamper barcodeStamp = new BarcodeStamper("IronPDF", BarcodeEncoding.Code39);
barcodeStamp.setHorizontalAlignment(HorizontalAlignment.LEFT);
barcodeStamp.setVerticalAlignment(VerticalAlignment.BOTTOM);
pdf.applyStamp(barcodeStamp);
pdf.saveAs(Paths.get("assets/barcode_stamped_sample.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
Inserir um código QR em um PDF
import java.io.IOException;
import java.nio.file.Paths;
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.stamp.BarcodeEncoding;
import com.ironsoftware.ironpdf.stamp.BarcodeStamper;
import com.ironsoftware.ironpdf.stamp.HorizontalAlignment;
import com.ironsoftware.ironpdf.stamp.VerticalAlignment;
public class StampQrCodeExample {
public static void main(String[] args) {
try {
PdfDocument pdf = PdfDocument.fromFile(Paths.get("assets/sample.pdf"));
BarcodeStamper QRStamp = new BarcodeStamper("IronPDF", BarcodeEncoding.QRCode);
QRStamp.setHeight(50);
QRStamp.setWidth(50);
QRStamp.setHorizontalAlignment(HorizontalAlignment.LEFT);
QRStamp.setVerticalAlignment(VerticalAlignment.BOTTOM);
pdf.applyStamp(QRStamp);
pdf.saveAs(Paths.get("assets/qrcode_stamped_sample.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
import java.io.IOException;
import java.nio.file.Paths;
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.stamp.BarcodeEncoding;
import com.ironsoftware.ironpdf.stamp.BarcodeStamper;
import com.ironsoftware.ironpdf.stamp.HorizontalAlignment;
import com.ironsoftware.ironpdf.stamp.VerticalAlignment;
public class StampQrCodeExample {
public static void main(String[] args) {
try {
PdfDocument pdf = PdfDocument.fromFile(Paths.get("assets/sample.pdf"));
BarcodeStamper QRStamp = new BarcodeStamper("IronPDF", BarcodeEncoding.QRCode);
QRStamp.setHeight(50);
QRStamp.setWidth(50);
QRStamp.setHorizontalAlignment(HorizontalAlignment.LEFT);
QRStamp.setVerticalAlignment(VerticalAlignment.BOTTOM);
pdf.applyStamp(QRStamp);
pdf.saveAs(Paths.get("assets/qrcode_stamped_sample.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
Adicionar uma marca d'água a um PDF
import java.io.IOException;
import java.nio.file.Paths;
import com.ironsoftware.ironpdf.PdfDocument;
public class AddWatermarkExample {
public static void main(String[] args) {
try {
PdfDocument pdf = PdfDocument.fromFile(Paths.get("assets/sample.pdf"));
String html = "<h1> Example Title <h1/>";
int watermarkOpacity = 30;
pdf.applyWatermark(html, watermarkOpacity);
pdf.saveAs(Paths.get("assets/watermarked_sample.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
import java.io.IOException;
import java.nio.file.Paths;
import com.ironsoftware.ironpdf.PdfDocument;
public class AddWatermarkExample {
public static void main(String[] args) {
try {
PdfDocument pdf = PdfDocument.fromFile(Paths.get("assets/sample.pdf"));
String html = "<h1> Example Title <h1/>";
int watermarkOpacity = 30;
pdf.applyWatermark(html, watermarkOpacity);
pdf.saveAs(Paths.get("assets/watermarked_sample.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
Utilizando formulários em PDFs
IronPDF Java fornece uma maneira simples e eficiente de definir e recuperar valores de campos de texto de formulário em um documento PDF usando a classe FormManager . Os desenvolvedores podem chamar o método setFieldValue para fornecer o nome e o valor do campo de texto.
Recupere o valor de um campo de formulário diretamente através da coleção de objetos FormManager de FormField, usando o nome ou índice relevante. Esse nível de controle sobre os campos do formulário facilita o trabalho com formulários PDF dinâmicos e interativos.
Criar e editar formulários
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.render.ChromePdfRenderOptions;
import java.io.IOException;
import java.nio.file.Paths;
public class CreateAndEditFormsExample {
public static void main(String[] args) {
try {
// #1 Use Case: Create a PDF Form from HTML Form Markup
Path outputLocation = Paths.get("assets/BasicForm.pdf");
String formHTML = "<html>" +
"<body>" +
"<h2>Editable PDF Form</h2>" +
"<form>" +
"First name: <br> <input type='text' name='firstname' value=''> <br>" +
"Last name: <br> <input type='text' name='lastname' value=''>" +
"</form>" +
"</body>" +
"</html>";
ChromePdfRenderOptions renderOptions = new ChromePdfRenderOptions();
renderOptions.setCreatePdfFormsFromHtml(true);
PdfDocument.renderHtmlAsPdf(formHTML, renderOptions).saveAs(outputLocation);
// #2 Use Case: Writing Values to the PDF Form
PdfDocument form = PdfDocument.fromFile(outputLocation);
// Set the value of the firstname input field.
form.getForm().setFieldValue("firstname", "Minnie");
// Set the value of the lastname input field.
form.getForm().setFieldValue("lastname", "Mouse");
// Save the changes to the PDF Form.
form.saveAs(Paths.get("assets/BasicForm_Filled.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
import com.ironsoftware.ironpdf.PdfDocument;
import com.ironsoftware.ironpdf.render.ChromePdfRenderOptions;
import java.io.IOException;
import java.nio.file.Paths;
public class CreateAndEditFormsExample {
public static void main(String[] args) {
try {
// #1 Use Case: Create a PDF Form from HTML Form Markup
Path outputLocation = Paths.get("assets/BasicForm.pdf");
String formHTML = "<html>" +
"<body>" +
"<h2>Editable PDF Form</h2>" +
"<form>" +
"First name: <br> <input type='text' name='firstname' value=''> <br>" +
"Last name: <br> <input type='text' name='lastname' value=''>" +
"</form>" +
"</body>" +
"</html>";
ChromePdfRenderOptions renderOptions = new ChromePdfRenderOptions();
renderOptions.setCreatePdfFormsFromHtml(true);
PdfDocument.renderHtmlAsPdf(formHTML, renderOptions).saveAs(outputLocation);
// #2 Use Case: Writing Values to the PDF Form
PdfDocument form = PdfDocument.fromFile(outputLocation);
// Set the value of the firstname input field.
form.getForm().setFieldValue("firstname", "Minnie");
// Set the value of the lastname input field.
form.getForm().setFieldValue("lastname", "Mouse");
// Save the changes to the PDF Form.
form.saveAs(Paths.get("assets/BasicForm_Filled.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
Preencha os formulários existentes
import com.ironsoftware.ironpdf.PdfDocument;
import java.io.IOException;
import java.nio.file.Paths;
public class FillExistingFormsExample {
public static void main(String[] args) {
try {
PdfDocument form = PdfDocument.fromFile("assets/pdfform.pdf");
// Set the value of the firstname input field.
form.getForm().setFieldValue("firstname", "Minnie");
// Set the value of the lastname input field.
form.getForm().setFieldValue("lastname", "Mouse");
// Save the changes to the PDF Form.
form.saveAs(Paths.get("assets/BasicForm_Filled.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
import com.ironsoftware.ironpdf.PdfDocument;
import java.io.IOException;
import java.nio.file.Paths;
public class FillExistingFormsExample {
public static void main(String[] args) {
try {
PdfDocument form = PdfDocument.fromFile("assets/pdfform.pdf");
// Set the value of the firstname input field.
form.getForm().setFieldValue("firstname", "Minnie");
// Set the value of the lastname input field.
form.getForm().setFieldValue("lastname", "Mouse");
// Save the changes to the PDF Form.
form.saveAs(Paths.get("assets/BasicForm_Filled.pdf"));
} catch (IOException e) {
e.printStackTrace();
}
}
}
Enviar PDF para impressão
O método de impressão do IronPDF permite que os desenvolvedores integrem facilmente a impressão de PDFs em seus aplicativos. Ao chamar o método [print](/java/object-reference/api/com/ironsoftware/ironpdf/PdfDocument.html#print() ), a caixa de diálogo de impressão do sistema operacional será aberta, oferecendo aos usuários opções para ajustar configurações como a impressora, o tamanho do papel e o número de cópias.
import com.ironsoftware.ironpdf.PdfDocument;
import java.awt.print.PrinterException;
public class PrintPdfExample {
public static void main(String[] args) {
try {
PdfDocument pdf = PdfDocument.renderHtmlAsPdf("<h1>Created with IronPDF!</h1>");
pdf.print();
} catch (PrinterException exception) {
System.out.println("Failed to print PDF");
exception.printStackTrace();
} catch (Exception ex) {
ex.printStackTrace();
}
}
}
import com.ironsoftware.ironpdf.PdfDocument;
import java.awt.print.PrinterException;
public class PrintPdfExample {
public static void main(String[] args) {
try {
PdfDocument pdf = PdfDocument.renderHtmlAsPdf("<h1>Created with IronPDF!</h1>");
pdf.print();
} catch (PrinterException exception) {
System.out.println("Failed to print PDF");
exception.printStackTrace();
} catch (Exception ex) {
ex.printStackTrace();
}
}
}
Conclusão
IronPDF é uma biblioteca PDF completa for Java que oferece uma ampla gama de recursos para criar, editar e manipular documentos PDF. Possui métodos robustos para extração de texto e imagem, permitindo que os desenvolvedores acessem e processem o conteúdo de PDFs. O IronPDF também oferece flexibilidade na personalização de metadados e configurações de segurança de PDFs, como tornar um PDF somente leitura ou protegido por senha. Inclui um método para comprimir PDFs, reduzir o tamanho dos arquivos e melhorar a eficiência da transmissão.
A biblioteca permite adicionar cabeçalhos e rodapés personalizados, bem como anotações, a um documento PDF. O recurso de marcadores permite que os desenvolvedores adicionem marcadores para facilitar a navegação dentro de um PDF.
O IronPDF oferece uma chave de avaliação gratuita, permitindo que os usuários testem seus recursos e funcionalidades antes de efetuar a compra. A licença IronPDF Java começa em $799, oferecendo uma solução econômica para empresas e indivíduos que buscam proteger e gerenciar seus arquivos PDF.
Perguntas frequentes
Quais são as principais funcionalidades da biblioteca Java PDF Editor?
A biblioteca Java PDF Editor oferece ferramentas abrangentes para edição e criação de PDFs, incluindo a adição de assinaturas, rodapés HTML, marcas d'água e anotações. Ela também suporta a mesclagem e divisão de PDFs, a personalização de tamanhos e orientações e a conversão de PDFs em imagens.
Como posso integrar uma biblioteca PDF ao meu projeto Java?
Para integrar uma biblioteca PDF como o IronPDF ao seu projeto Java, baixe a biblioteca do site oficial do IronPDF e adicione-a como uma dependência na configuração de compilação do seu projeto.
Como posso modificar a estrutura de um documento PDF em Java?
Você pode modificar a estrutura de um documento PDF em Java usando o IronPDF. Utilize métodos como prependPdf , copyPages e removePages para adicionar, copiar e excluir páginas.
É possível definir margens e metadados personalizados para PDFs?
Sim, o IronPDF permite definir margens personalizadas e modificar metadados do PDF, incluindo autor e palavras-chave, usando a classe MetadataManager .
Posso converter documentos PDF em formatos de imagem usando Java?
Com o IronPDF, você pode converter páginas PDF em formatos de imagem usando o método toBufferedImages , onde você pode definir as dimensões da imagem e o DPI.
Como adiciono marcas d'água personalizadas a arquivos PDF?
Para adicionar marcas d'água personalizadas a arquivos PDF, use o método applyWatermark do IronPDF. Você pode especificar o conteúdo da marca d'água, como HTML, e ajustar sua opacidade.
O IronPDF oferece suporte à proteção por senha para documentos PDF?
Sim, o IronPDF suporta proteção por senha, permitindo que você proteja seus documentos, impedindo o acesso e alterações não autorizados.
Quais ferramentas estão disponíveis para manipular formulários PDF em Java?
O IronPDF fornece uma classe FormManager para criar, editar e preencher formulários PDF. Ela facilita a definição e a recuperação de valores dos campos do formulário.
Como posso garantir a segurança de documentos com assinaturas digitais em PDFs?
O IronPDF permite a assinatura segura de documentos PDF usando certificados digitais X509Certificate2, garantindo a autenticidade e impedindo alterações não autorizadas.
É possível compactar arquivos PDF para reduzir seu tamanho?
O IronPDF inclui métodos para comprimir arquivos PDF, o que ajuda a reduzir o tamanho dos arquivos, mantendo a qualidade do documento.




