7

私はPDFBoxのドキュメントに本当に苦労しています。そのような人気のある図書館の情報は、地面では少し薄いようです(私にとっては!)。

とにかく、私が抱えている問題はPDFの保護に関係しています。現時点で必要なのは、ユーザーのアクセス許可を制御することだけです。具体的には、ユーザーがPDFを変更できないようにしたいです。

アクセス許可コードを省略すると、すべてが完全に機能します。外部リソースからPDFを読んでいます。次に、フィールドを読み取ってデータを入力し、新しいPDFを保存する前にいくつかの画像を追加します。それはすべて完璧に機能します。

アクセスを管理するために次のコードを追加すると、問題が発生します。

/* Secure the PDF so that it cannot be edited */
try {
    String ownerPassword = "DSTE$gewRges43";
    String userPassword = "";

    AccessPermission ap = new AccessPermission();
    ap.setCanModify(false);

    StandardProtectionPolicy spp = new StandardProtectionPolicy(ownerPassword, userPassword, ap);
    pdf.protect(spp);
} catch (BadSecurityHandlerException ex) {
    Logger.getLogger(PDFManager.class.getName()).log(Level.SEVERE, null, ex);
}

このコードを追加すると、すべてのテキストと画像が送信pdfから削除されます。フィールドはドキュメントにまだ存在しますが、すべて空であり、元のPDFの一部であり、コードに動的に追加されたすべてのテキストと画像が失われます。

更新:わかりました。問題はフォームフィールドに関連するバグが原因であることがわかります。フォームフィールドを使用せずに別のアプローチを試し、それが何をもたらすかを確認します。

4

1 に答える 1

10

私はこの問題の解決策を見つけました。PDFが外部ソースからのものである場合、PDFが保護または暗号化されているように見えることがあります。

外部ソースからPDFドキュメントをロードし、保護を追加するときに空白の出力が表示される場合は、暗号化されたドキュメントで作業している可能性があります。PDFドキュメントを処理するストリーム処理システムがあります。したがって、次のコードが機能します。PDF入力を使用しているだけの場合は、以下のコードをフローに統合できます。

public InputStream convertDocument(InputStream dataStream) throws Exception {
    // just acts as a pass through since already in pdf format
    PipedOutputStream os = new PipedOutputStream();
    PipedInputStream is = new PipedInputStream(os);

    System.setProperty("org.apache.pdfbox.baseParser.pushBackSize", "2024768"); //for large files

    PDDocument doc = PDDocument.load(dataStream, true);

    if (doc.isEncrypted()) { //remove the security before adding protections
        doc.decrypt("");
        doc.setAllSecurityToBeRemoved(true);
    }
    doc.save(os);
    doc.close();
    dataStream.close();
    os.close();
    return is;
}

次に、返されたInputStreamを取得して、セキュリティアプリケーションに使用します。

   PipedOutputStream os = new PipedOutputStream();
   PipedInputStream is = new PipedInputStream(os);

   System.setProperty("org.apache.pdfbox.baseParser.pushBackSize", "2024768");
   InputStream dataStream = secureData.data();

   PDDocument doc = PDDocument.load(dataStream, true);
   AccessPermission ap = new AccessPermission();
   //add what ever perms you need blah blah...
   ap.setCanModify(false);
   ap.setCanExtractContent(false);
   ap.setCanPrint(false);
   ap.setCanPrintDegraded(false);
   ap.setReadOnly();

   StandardProtectionPolicy spp = new StandardProtectionPolicy(UUID.randomUUID().toString(), "", ap);

   doc.protect(spp);

   doc.save(os);
   doc.close();
   dataStream.close();
   os.close();

これで、空白の出力のない適切なドキュメントが返されるはずです。

秘訣は、最初に暗号化を削除することです!

于 2014-03-13T03:25:24.313 に答える