PHP/MySqlで構築されたDBシステムがあります。私はこれでかなり新しいです。システムにより、ユーザーは請求書をアップロードできます。他の人は、請求書を支払う許可を与えます。経理担当者が小切手をアップロードします。小切手がアップロードされた後、表紙として PDF を生成し、PDFTK (Ben Squire の PDFTK-PHP-Library を使用) を使用してすべてのファイルを結合し、ダウンロードする単一の PDF をユーザーに提示します。
一部のユーザーが PDF ファイルをアップロードすると、PDF を他のファイルと結合しようとすると、PDFTK が無期限にハングします (ただし、ほとんどの場合は問題なく動作します)。エラーは返されず、ハングするだけです。システムに戻るには、ユーザーはキャッシュをクリアして再ログインする必要があります。サーバーによってログに記録されるエラー メッセージはなく、フリーズするだけです。Acrobat でファイルを見て動作するファイルと動作しないファイルの唯一の違いは、問題のあるファイルが正当なサイズ (8.5 x 14) であることです ... しかし、独自の正当なサイズのファイルを作成して試してみると、それは正常に動作します。
Putty を使用してコマンド ラインに移動し、同じ問題を再現しました。PDFTK はファイルを読み取ることができず、コマンド ラインでもハングします。FPDFを使用してファイルを結合し、ファイルでエラーを取得するPDFMergeを使用してみました(これから返されるエラーは次のとおりです:FPDFエラー:予期された場所でオブジェクト(4、0)が見つかりません)。コマンド ラインで ImageMagick を使用して PDF を JPG に変換できましたが、「警告: ファイルに無効な xref エントリがあります: 2. xref テーブルを再構築しています。」というエラーが表示されます。次に、それをjpgに変換しますが、他のいくつかのあまり役に立たない警告を出します.
システムをハングアップさせずに有効かどうかを判断するために PHP に PDF ファイルをチェックさせることができれば、ImageMagick を使用してファイルを変換し、それを PDF に戻すことができますが、すべてのファイルに対してこれを実行したくはありません。アップロード時にファイルの有効性をチェックして、システムをハングさせずに変換する必要があるかどうかを確認するにはどうすればよいですか?
問題を引き起こしているファイルへのリンクは次のとおりです: http://www.cssc-testing.org/accounting/school_9/20130604-a1atransportation-1.pdf
あなたが提供できるガイダンスを事前にありがとう!
私のコード(私は新しいので、あまりきれいではないと思います):
$pdftk = new pdftk();
if($create_cover) { $pdftk->setInputFile(array("filename" => $cover_page['server'])); }
// Load a list of attachments
$sql = "SELECT * FROM actg_attachments WHERE trans_id = {$trans_id}";
$attachments = Attachment::find_by_sql($sql);
foreach($attachments as $attachment) {
// Check if the file exists from the attachments
$attachment->set_variables();
$file = $attachment->abs_path . DS . $attachment->filename;
if(file_exists($file)){
// Use the pdftk tool to attach the documents to this PDF
$pdftk->setInputFile(array("filename" => $file));
}
}
$pdftk->setOutputFile($save_file);
$pdftk->_renderPdf();
呼び出している $pdftk クラスは次のものです: https://github.com/bensquire/php-pdtfk-toolkit