이 기사에서는 PHP를 사용하여 PDF 파일을 생성하는 방법에 대해 설명합니다. TCPDF 라이브러리를 사용하여 프로그래밍 방식으로 PDF 문서를 만듭니다.
사용자가 주문 영수증, 청구서, 송장 등의 문서를 다운로드하거나 인쇄할 수 있는 웹사이트를 개발하는 경우 몇 가지 옵션이 있습니다. 문서를 브라우저에 인라인으로 표시하거나 다운로드할 수 있도록 제공할 수 있습니다. PDF는 문서를 다운로드할 때 가장 좋은 형식 중 하나이며 텍스트 형식을 보존하는 데 탁월합니다.
PHP 웹사이트에서 PDF 파일을 생성하는 방법을 배우고 싶다면 제대로 찾아오셨습니다!
이 섹션에서는 TCPDF 라이브러리를 설치하는 방법을 알아봅니다.
서버에 TCPDF 라이브러리를 설치하는 방법에는 여러 가지가 있습니다. TCPDF 라이브러리는 Packagist 및 GitHub에서 사용할 수 있으므로 Composer를 사용하거나 GitHub에서 복제할 수 있습니다. 우리의 경우 Composer를 사용하여 설치하겠습니다.
Composer를 사용하여 TCPDF 라이브러리를 설치하려면 다음 명령을 실행하세요.
으아아아설치가 성공적으로 완료되면 다음 코드 조각에 표시된 대로 PHP 스크립트에 autoload.php 파일을 포함해야 합니다.
으아아아이렇게 하면 TCPDF 라이브러리에서 제공하는 모든 실용적인 방법을 사용할 수 있습니다.
이 섹션에서는 PDF 송장을 생성하는 방법을 보여주는 실제 사례를 작성해 보겠습니다. TCPDF 라이브러리는 PDF 문서 생성을 위한 참조로 사용할 수 있는 다양한 미리 만들어진 템플릿을 제공합니다. 그러나 우리는 처음부터 송장을 생성할 것입니다.
이전 섹션에서 이미 언급했듯이 TCPDF 라이브러리는 머리글과 바닥글이 있는 범용 PDF 파일을 생성할 수 있는 다양한 미리 만들어진 템플릿을 제공합니다. 이는 기본 형식과 설정에 만족하는 경우 유용합니다. 하지만 내용뿐만 아니라 머리글과 바닥글도 맞춤설정하려면 TCPDF
클래스를 확장하고 해당 메서드를 재정의해야 합니다.
이 예에서는 customPdfGenerator.php 및 example.php라는 두 개의 파일을 생성합니다. customPdfGenerator.php 파일에서 핵심 CustomPdfGenerator
类,它将扩展核心 TCPDF
类并重写几个方法。在 example.php 文件中,我们将了解如何使用 CustomPdfGenerator
클래스를 확장하고 몇 가지 메소드를 재정의하는
CustomPdfGenerator
파일에서 수업
다음 내용으로 CustomPdfGenerator
类扩展了 TCPDF
类,因此我们可以使用 TCPDF
customPdfGenerator.php
으아아아
TCPDF
类的唯一目的是我们不想使用内置的页眉和页脚组件。因此,我们重写了类中的 header
和 footer
标头
클래스에서 제공하는 모든 유틸리티 메서드를 사용하여 PDF 문서의 형식을 지정하고 생성할 수 있습니다. 클래스를 직접 사용하는 대신 자체 클래스를 만드는 유일한 목적은 내장된 머리글 및 바닥글 구성 요소를 사용하고 싶지 않다는 것입니다. 따라서 클래스의 header
및 footer
메서드를 재정의합니다.
Image
方法。接下来,我们使用 SetFont 方法设置文本的字体系列和字体大小,这些文本将添加到标题中。最后,我们使用 Cell
방법
제목에는 회사 로고와 소유자 이름을 표시하려고 합니다. 어떻게 작동하는지 이해하기 위해 헤더 메소드를 살펴보겠습니다.
으아아아먼저 이미지 방식을 사용하여 왼쪽에 회사 로고를 그립니다. 중요한 것은 오른쪽에 소유자 이름을 인쇄하려면 로고 이미지의 절대 경로를
메소드에 전달해야 한다는 것입니다.이러한 메서드에서는 많은 매개 변수를 전달할 수 있다는 점을 알게 될 것입니다. 이 문서에서 모든 매개 변수를 논의하는 것은 불가능하므로 자세히 살펴보는 것이 좋습니다.
Footer
바닥글 방법
바닥글에 일부 정적 텍스트를 표시하려고 하므로 메소드는 다음 코드 조각에 표시된 것처럼 매우 간단합니다.
으아아아바닥글 섹션은 다음과 같습니다: printTable
方法,我们稍后再讨论这个方法。 printTable
方法与 TCPDF
CustomPdfGenerator
printTable
메서드가 있는데, 이 메서드에 대해서는 나중에 논의하겠습니다. printTable
메소드는 CustomPdfGenerator
수업입니다. 다음 섹션에서는 이를 사용하는 방법과 전체 PDF 송장을 생성하는 다른 방법을 살펴보겠습니다!
example.php 파일 이전 섹션에서는 사용자 정의 머리글과 바닥글이 있는 PDF 파일을 생성하는 데 사용할 수 있는
래퍼 클래스를 만들었습니다. 이 섹션에서는 이를 사용하는 방법을 보여줍니다.다음 내용으로
example.php 파일을 생성해 보세요.
으아아아
TCPDF
위 파일의 중요한 부분을 살펴보겠습니다.
먼저
接下来,我们实例化了 CustomPdfGenerator
类以及默认设置。在实际开始写入 PDF 文件之前,我们还调用了一些方法来进行默认设置。
$pdf = new CustomPdfGenerator(PDF_PAGE_ORIENTATION, PDF_UNIT, PDF_PAGE_FORMAT, true, 'UTF-8', false); $pdf->SetDefaultMonospacedFont(PDF_FONT_MONOSPACED); $pdf->SetMargins(PDF_MARGIN_LEFT, PDF_MARGIN_TOP, PDF_MARGIN_RIGHT); $pdf->SetAutoPageBreak(TRUE, PDF_MARGIN_BOTTOM); $pdf->setImageScale(PDF_IMAGE_SCALE_RATIO); $pdf->setFontSubsetting(true); $pdf->SetFont('dejavusans', '', 12, '', true);
我们在上面代码片段中使用的常量已在 tcpdf_autoconfig.php 文件中定义。要覆盖这些常量之一,您只需在脚本中定义它,TCPDF 库将使用您的值。例如,PDF_PAGE_ORIENTATION
常量的默认值为 P
(纵向),如果要将其更改为 L
(横向),则只需包含 define ('PDF_PAGE_ORIENTATION', 'L ');脚本中的
。
接下来,有一个重要的片段,它调用 AddPage
方法,该方法实际上在 PDF 文档中添加一个新页面。
// start a new page $pdf->AddPage();
现在我们已经添加了一个页面,我们可以开始在此页面上书写。
接下来,我们使用 Write
和 writeHTML
方法在左侧打印日期和发票号码。
// date and invoice no $pdf->Write(0, "\n", '', 0, 'C', true, 0, false, false, 0); $pdf->writeHTML("<b>DATE:</b> 01/01/2021"); $pdf->writeHTML("<b>INVOICE#</b>12"); $pdf->Write(0, "\n", '', 0, 'C', true, 0, false, false, 0);
Write
方法从当前位置开始打印文本,您可以使用它来打印纯文本。另一方面, writeHTML
方法允许您保留文本中的 HTML 格式。虽然 writeHTML
方法提供了有限的 HTML 格式支持,但它涵盖了日常开发中经常使用的所有 HTML 标签。
同样,我们在 writeHTML
方法的帮助下打印了地址和收单地址。
// address $pdf->writeHTML("84 Norton Street,"); $pdf->writeHTML("NORMANHURST,"); $pdf->writeHTML("New South Wales, 2076"); $pdf->Write(0, "\n", '', 0, 'C', true, 0, false, false, 0); // bill to $pdf->writeHTML("<b>BILL TO:</b>", true, false, false, false, 'R'); $pdf->writeHTML("22 South Molle Boulevard,", true, false, false, false, 'R'); $pdf->writeHTML("KOOROOMOOL,", true, false, false, false, 'R'); $pdf->writeHTML("Queensland, 4854", true, false, false, false, 'R'); $pdf->Write(0, "\n", '', 0, 'C', true, 0, false, false, 0);
默认情况下,writeHTML
方法在左侧打印文本。如果要打印右对齐文本,可以传递 R
作为 writeHTML
方法的最后一个参数,如上面的代码片段所示。在我们的例子中,我们希望显示右对齐的收单地址。
让我们快速浏览一下到目前为止我们已经构建的内容。
接下来,我们有一个代码片段,它负责打印项目信息表的繁重工作。
// invoice table starts here $header = array('DESCRIPTION', 'UNITS', 'RATE $', 'AMOUNT'); $data = array( array('Item #1','1','100','100'), array('Item #2','2','200','400') ); $pdf->printTable($header, $data); $pdf->Ln();
还记得我们在customPdfGenerator.php类中定义的printTable
方法吗?现在是时候详细探讨它了。让我们拉入 printTable
方法的代码。
public function printTable($header, $data) { $this->SetFillColor(0, 0, 0); $this->SetTextColor(255); $this->SetDrawColor(128, 0, 0); $this->SetLineWidth(0.3); $this->SetFont('', 'B', 12); $w = array(110, 17, 25, 30); $num_headers = count($header); for($i = 0; $i < $num_headers; ++$i) { $this->Cell($w[$i], 7, $header[$i], 1, 0, 'C', 1); } $this->Ln(); // Color and font restoration $this->SetFillColor(224, 235, 255); $this->SetTextColor(0); $this->SetFont(''); // table data $fill = 0; $total = 0; foreach($data as $row) { $this->Cell($w[0], 6, $row[0], 'LR', 0, 'L', $fill); $this->Cell($w[1], 6, $row[1], 'LR', 0, 'R', $fill); $this->Cell($w[2], 6, number_format($row[2]), 'LR', 0, 'R', $fill); $this->Cell($w[3], 6, number_format($row[3]), 'LR', 0, 'R', $fill); $this->Ln(); $fill=!$fill; $total+=$row[3]; } $this->Cell($w[0], 6, '', 'LR', 0, 'L', $fill); $this->Cell($w[1], 6, '', 'LR', 0, 'R', $fill); $this->Cell($w[2], 6, '', 'LR', 0, 'L', $fill); $this->Cell($w[3], 6, '', 'LR', 0, 'R', $fill); $this->Ln(); $this->Cell($w[0], 6, '', 'LR', 0, 'L', $fill); $this->Cell($w[1], 6, '', 'LR', 0, 'R', $fill); $this->Cell($w[2], 6, 'TOTAL:', 'LR', 0, 'L', $fill); $this->Cell($w[3], 6, $total, 'LR', 0, 'R', $fill); $this->Ln(); $this->Cell(array_sum($w), 0, '', 'T'); }
首先,在实际开始打印发票表的标题行之前,我们调用了几个方法来设置字体大小、填充颜色、线宽和文本颜色。接下来,我们在 Cell
方法的帮助下循环遍历 $header
数组并打印表头标题。
Cell
方法允许您打印具有可选边框、背景颜色和字符串的单元格(矩形区域)。您还可以指定在单元格中打印的文本的对齐方式。因此,Cell
方法是构建表的完美候选方法。
打印表格标题标题后,我们循环遍历 $data
数组并打印它以完成整个表格。最后,我们多次调用 Cell
方法来打印总金额。
表格的快速预览应如下所示:
现在,让我们回到 example.php 文件来查看最后几行代码。
在发票末尾,我们将打印一些评论和联系信息,如以下代码片段所示。
// comments $pdf->SetFont('', '', 12); $pdf->writeHTML("<b>OTHER COMMENTS:</b>"); $pdf->writeHTML("Method of payment: <i>PAYPAL</i>"); $pdf->writeHTML("PayPal ID: <i>katie@paypal.com"); $pdf->Write(0, "\n\n\n", '', 0, 'C', true, 0, false, false, 0); $pdf->writeHTML("If you have any questions about this invoice, please contact:", true, false, false, false, 'C'); $pdf->writeHTML("Katie A Falk, (07) 4050 2235, katie@sks.com", true, false, false, false, 'C');
最后,我们使用 Output
方法将 PDF 文件保存到磁盘。如果您不想将 PDF 文件保存在磁盘上,而只想将其发送到浏览器,则需要在 Output
方法的第二个参数中使用 I
。
继续运行 example.php
文件,它应该生成如下屏幕截图所示的 PDF 文件。
这就是如何使用 TCPDF 库在 PHP 中创建 PDF 文档。我们创建了一个真实示例来演示 TCPDF 库提供的一些不同的 API。
TCPDF 官方文档提供了许多现成的模板,您可以探索它们以了解内置 API,我鼓励您探索它!
如果您想了解有关在网站中包含 PDF 的更多信息,请查看以下链接:
위 내용은 PHP에서 PDF 파일을 생성하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!