Apabila menjana PDF dalam Laravel menggunakan DomPDF, pengendalian imej boleh menjadi rumit. Satu cabaran biasa ialah penggunaan memori, terutamanya apabila berurusan dengan berbilang imej dalam satu PDF. Dalam siaran ini, saya akan berkongsi penyelesaian yang mantap untuk membenamkan imej dalam PDF Laravel sambil mengurus memori dengan cekap.
DomPDF memerlukan imej untuk dibenamkan terus dalam HTML sebagai rentetan berkod base64. Walau bagaimanapun, memuatkan berbilang imej ke dalam memori secara serentak boleh melebihi had memori PHP dengan cepat, terutamanya apabila menjana katalog atau laporan yang besar.
Saya telah membangunkan pendekatan cekap ingatan yang:
Inilah penyelesaian lengkapnya:
@php ini_set('memory_limit', '256M'); function processImage($imagePath) { if (!file_exists($imagePath)) { // Return a 1-pixel transparent image as fallback return 'iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAQAAAC1HAwCAAAAC0lEQVR42mNkYAAAAAYAAjCB0C8AAAAASUVORK5CYII='; } // Read file in chunks to avoid memory issues $handle = fopen($imagePath, 'rb'); $contents = ''; while (!feof($handle)) { $contents .= fread($handle, 8192); // Read 8KB at a time } fclose($handle); return base64_encode($contents); } @endphp
Mari kita pecahkan komponen utama:
ini_set('memory_limit', '256M');
Kita mulakan dengan menetapkan had ingatan yang munasabah. 256MB biasanya mencukupi untuk kebanyakan tugas penjanaan PDF sambil menghalang penggunaan memori yang lari.
$handle = fopen($imagePath, 'rb'); $contents = ''; while (!feof($handle)) { $contents .= fread($handle, 8192); }
Daripada memuatkan keseluruhan imej ke dalam memori sekaligus menggunakan file_get_contents(), kami:
Pendekatan ini mengurangkan penggunaan memori dengan ketara apabila memproses imej besar.
if (!file_exists($imagePath)) { return 'iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAQAAAC1HAwCAAAAC0lEQVR42mNkYAAAAAYAAjCB0C8AAAAASUVORK5CYII='; }
Jika fail imej tiada, kami mengembalikan PNG lutsinar 1x1 berkod base64 dan bukannya membuang ralat. Ini memastikan penjanaan PDF anda tidak akan gagal kerana imej yang hilang.
Berikut ialah cara untuk melaksanakan penyelesaian ini dalam templat Blade anda:
<div> @php $imagePath = $item['image_url']; if (empty($item['image_url'])) { $imagePath = public_path('images/placeholder.jpg'); } $base64Image = processImage($imagePath); @endphp <img src="data:image/png;base64,{{ $base64Image }}" alt=""> </div>
Templat:
$item['image_url'] memegang laluan mutlak penuh imej seperti /var/www/html/....
Untuk memastikan imej anda dipaparkan dengan betul dalam PDF, pertimbangkan sifat CSS ini:
.item-image img { object-fit: cover; object-position: center; border-radius: 0.375rem; max-width: 100%; height: auto; }
Ini memastikan imej:
Penyelesaian ini menawarkan beberapa kelebihan:
Menjana PDF dengan imej dalam Laravel tidak semestinya proses intensif memori. Dengan melaksanakan pembacaan fail berasaskan ketulan dan pengendalian ralat yang betul, anda boleh mencipta sistem penjanaan PDF yang mantap yang berfungsi dengan pasti pada skala.
Ingat untuk melaraskan had memori dan saiz ketulan berdasarkan keperluan khusus anda dan kekangan pelayan. Pantau penggunaan memori aplikasi anda dalam pengeluaran untuk memastikan prestasi optimum.
Penyelesaian ini amat berguna untuk menjana katalog lelongan, penyenaraian produk atau sebarang dokumen PDF lain yang memerlukan berbilang imej sambil mengekalkan prestasi dan kebolehpercayaan.
Atas ialah kandungan terperinci Memaparkan BaseImages dalam Laravel PDF dengan DomPDF dengan cekap. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!