Skip to content

Cấu hình Laravel

Mọi tùy chọn nằm trong config/tcpdf-next.php. Publish bằng lệnh:

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

Mặc định trang

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],
],
KeyBiến EnvMặc địnhMô tả
page.formatTCPDF_PAGE_FORMATA4Kích thước trang ISO (A4, Letter, Legal, v.v.)
page.orientation--portraitHướng trang mặc định
page.unit--mmĐơn vị cho mọi giá trị tọa độ

Cấu hình Font

php
'fonts' => [
    'directory'      => resource_path('fonts'),
    'cache'          => storage_path('framework/cache/tcpdf-next/fonts'),
    'default_family' => 'Helvetica',
    'default_size'   => 11.0,
    'subset'         => true,
],
KeyMặc địnhMô tả
fonts.directoryresource_path('fonts')Đường dẫn tới file font TTF/OTF tùy chỉnh
fonts.cachestorage_path('.../fonts')Cache font metric đã biên dịch
fonts.default_familyHelveticaFont family khi không chỉ định
fonts.default_size11.0Kích thước font mặc định tính bằng point
fonts.subsettrueChỉ nhúng glyph đã dùng để giảm kích thước file

Tuân thủ PDF/A

php
'pdfa' => [
    'enabled'       => env('TCPDF_PDFA', false),
    'version'       => 'PDF/A-4',
    'output_intent' => 'sRGB',
],
KeyBiến EnvMặc địnhMô tả
pdfa.enabledTCPDF_PDFAfalseBật tuân thủ PDF/A
pdfa.version--PDF/A-4Phiên bản PDF/A đích
pdfa.output_intent--sRGBICC output intent profile

Cài đặt mã hóa

php
'encryption' => [
    'level'       => 'aes-256',
    'user_pass'   => env('TCPDF_USER_PASS', ''),
    'owner_pass'  => env('TCPDF_OWNER_PASS', ''),
    'permissions' => ['print', 'copy'],
],
KeyMặc địnhMô tả
encryption.levelaes-256Thuật toán: aes-256, aes-128, rc4-128
encryption.user_pass''Mật khẩu để mở document
encryption.owner_pass''Mật khẩu để thay đổi quyền
encryption.permissions['print', 'copy']Cho phép: print, copy, modify, annotate

Cài đặt chữ ký số

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', ''),
],
KeyBiến EnvMặc địnhMô tả
signature.enabledTCPDF_SIGN_ENABLEDfalseBật ký tự động
signature.cert_pathTCPDF_SIGN_CERT''Đường dẫn tới certificate PEM
signature.key_pathTCPDF_SIGN_KEY''Đường dẫn tới private key PEM
signature.levelTCPDF_SIGN_LEVELB-BCấp PAdES (B-B, B-T, B-LT, B-LTA)
signature.tsa_urlTCPDF_TSA_URL''URL timestamp authority RFC 3161

Cấu hình Queue

php
'queue' => [
    'connection' => env('TCPDF_QUEUE_CONNECTION', null),
    'queue'      => env('TCPDF_QUEUE', 'pdf'),
    'disk'       => env('TCPDF_DISK', 'local'),
    'tries'      => 3,
    'backoff'    => 30,
    'timeout'    => 120,
],
KeyBiến EnvMặc địnhMô tả
queue.connectionTCPDF_QUEUE_CONNECTIONnullQueue connection (null = mặc định)
queue.queueTCPDF_QUEUEpdfTên queue cho PDF job
queue.diskTCPDF_DISKlocalFilesystem disk mặc định cho output
queue.tries--3Số lần retry tối đa
queue.backoff--30Giây giữa các lần retry
queue.timeout--120Timeout job tính bằng giây

Bước tiếp theo

  • Tổng quan — Kiến trúc package và service provider binding
  • Pdf Facade — Cách giá trị config áp dụng cho document mới
  • Queue Job — Cấu hình queue trong thực tế

Phân phối theo giấy phép LGPL-3.0-or-later.