Skip to content

Laravel設定

すべてのオプションは config/tcpdf-next.php に記述されています。以下のコマンドでパブリッシュしてください:

bash
php artisan vendor:publish --tag=tcpdf-next-config

ページデフォルト

php
'page' => [
    'format'      => env('TCPDF_PAGE_FORMAT', 'A4'),
    'orientation'  => 'portrait',   // 'portrait' | 'landscape'
    'unit'         => 'mm',         // 'mm' | 'pt' | 'cm' | 'in'
    'margin'       => ['top' => 20.0, 'right' => 15.0, 'bottom' => 20.0, 'left' => 15.0],
],
キー環境変数デフォルト説明
page.formatTCPDF_PAGE_FORMATA4ISOページサイズ(A4、Letter、Legalなど)
page.orientation--portraitデフォルトのページ向き
page.unit--mmすべての座標値の単位

フォント設定

php
'fonts' => [
    'directory'      => resource_path('fonts'),
    'cache'          => storage_path('framework/cache/tcpdf-next/fonts'),
    'default_family' => 'Helvetica',
    'default_size'   => 11.0,
    'subset'         => true,
],
キーデフォルト説明
fonts.directoryresource_path('fonts')カスタムTTF/OTFフォントファイルのパス
fonts.cachestorage_path('.../fonts')コンパイル済みフォントメトリクスのキャッシュ
fonts.default_familyHelvetica指定がない場合のフォントファミリー
fonts.default_size11.0デフォルトのフォントサイズ(ポイント)
fonts.subsettrueファイルサイズ削減のため使用グリフのみ埋め込み

PDF/A準拠

php
'pdfa' => [
    'enabled'       => env('TCPDF_PDFA', false),
    'version'       => 'PDF/A-4',
    'output_intent' => 'sRGB',
],
キー環境変数デフォルト説明
pdfa.enabledTCPDF_PDFAfalsePDF/A準拠を有効化
pdfa.version--PDF/A-4対象PDF/Aバージョン
pdfa.output_intent--sRGBICC出力インテントプロファイル

暗号化設定

php
'encryption' => [
    'level'       => 'aes-256',
    'user_pass'   => env('TCPDF_USER_PASS', ''),
    'owner_pass'  => env('TCPDF_OWNER_PASS', ''),
    'permissions' => ['print', 'copy'],
],
キーデフォルト説明
encryption.levelaes-256アルゴリズム:aes-256aes-128rc4-128
encryption.user_pass''ドキュメントを開くためのパスワード
encryption.owner_pass''権限を変更するためのパスワード
encryption.permissions['print', 'copy']許可:printcopymodifyannotate

デジタル署名設定

php
'signature' => [
    'enabled'   => env('TCPDF_SIGN_ENABLED', false),
    'cert_path' => env('TCPDF_SIGN_CERT', ''),
    'key_path'  => env('TCPDF_SIGN_KEY', ''),
    'key_pass'  => env('TCPDF_SIGN_KEY_PASS', ''),
    'level'     => env('TCPDF_SIGN_LEVEL', 'B-B'),
    'tsa_url'   => env('TCPDF_TSA_URL', ''),
],
キー環境変数デフォルト説明
signature.enabledTCPDF_SIGN_ENABLEDfalse自動署名を有効化
signature.cert_pathTCPDF_SIGN_CERT''PEM証明書のパス
signature.key_pathTCPDF_SIGN_KEY''PEM秘密鍵のパス
signature.levelTCPDF_SIGN_LEVELB-BPAdESレベル(B-BB-TB-LTB-LTA
signature.tsa_urlTCPDF_TSA_URL''RFC 3161タイムスタンプ認証局URL

キュー設定

php
'queue' => [
    'connection' => env('TCPDF_QUEUE_CONNECTION', null),
    'queue'      => env('TCPDF_QUEUE', 'pdf'),
    'disk'       => env('TCPDF_DISK', 'local'),
    'tries'      => 3,
    'backoff'    => 30,
    'timeout'    => 120,
],
キー環境変数デフォルト説明
queue.connectionTCPDF_QUEUE_CONNECTIONnullキュー接続(null = デフォルト)
queue.queueTCPDF_QUEUEpdfPDFジョブのキュー名
queue.diskTCPDF_DISKlocal出力先のデフォルトファイルシステムディスク
queue.tries--3最大リトライ回数
queue.backoff--30リトライ間の秒数
queue.timeout--120ジョブのタイムアウト(秒)

次のステップ

  • 概要 — パッケージのアーキテクチャとService Providerバインディング
  • Pdfファサード — 設定値が新しいドキュメントに適用される仕組み
  • キュージョブ — キュー固有の設定の実践

LGPL-3.0-or-later ライセンスの下で公開されています。