Используя Google "java пример пароля openpdf" Я нашел этот веб-сайт: https://knpcode.com/java-programs/password-protected-pdf-using-openpdf-java/ с некоторой информацией по вашему вопросу.
Вот две программы-примеры (просто скопируйте / вставьте их, а не тест). Не забудьте включить Bouncy Castle в качестве поставщика безопасности.
Зашифровать («безопасный») PDF-файл:
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import com.lowagie.text.Document;
import com.lowagie.text.DocumentException;
import com.lowagie.text.Paragraph;
import com.lowagie.text.pdf.PdfWriter;
public class PasswordProtectedPDF {
public static final String ENCRYPTED_PDF = "F://knpcode//result//OpenPDF//PP.pdf";
// User and owner password
final static String USER_PASSWORD = "user";
final static String OWNER_PASSWORD = "owner";
public static void main(String[] args) {
try {
Document doc = new Document();
PdfWriter writer = PdfWriter.getInstance(doc, new FileOutputStream(ENCRYPTED_PDF));
// set password, user permissions and encryption
writer.setEncryption(USER_PASSWORD.getBytes(), OWNER_PASSWORD.getBytes(), PdfWriter.ALLOW_PRINTING, PdfWriter.ENCRYPTION_AES_128);
doc.open();
Paragraph para = new Paragraph("Password protected PDF where only content printing is permitted content can't be copied.");
doc.add(para);
doc.close();
writer.close();
} catch (DocumentException | FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
Чтение PDF-файла, защищенного паролем, с использованием OpenPDF:
import java.io.IOException;
import com.lowagie.text.pdf.PdfReader;
import com.lowagie.text.pdf.parser.PdfTextExtractor;
public class ReadPDF {
// PDF to be read
public static final String READ_PDF = "F://knpcode//result//OpenPDF//PP.pdf";
final static String OWNER_PASSWORD = "owner";
public static void main(String[] args) {
PdfReader pdfreader = null;
try {
pdfreader = new PdfReader(READ_PDF, OWNER_PASSWORD.getBytes());
// get pages in PDF
int pages = pdfreader.getNumberOfPages();
PdfTextExtractor pdfTextExtractor = new PdfTextExtractor(pdfreader);
// Iterate through pages to read content
for(int i = 1; i <= pages; i++) {
// Extract content of each page
String contentOfPage = pdfTextExtractor.getTextFromPage(i, true);
System.out.println(contentOfPage );
}
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally {
if(pdfreader != null) {
pdfreader.close();
}
}
}
}