- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一直在尝试使用 PHP 创建一个可以下载的动态 PDF 文件。我已经包含了下面的代码。文档显示空白数据,PDF 文件上没有任何内容。
<?php
$output = '';
$quote = $_GET['quote'];
function fetchData(){
include 'config.php';
$quote = $_GET['quote'];
$output = '';
$query = "SELECT * FROM quote_list, quotation WHERE quote_list.quote_id = quotation.id AND quote_list.quote_id = '$quote'";
$result = mysqli_query($connect, $query);
if($row = mysqli_fetch_assoc($result)){
$companyName = $row['name'];
$email = $row['email'];
$countQuery = "SELECT COUNT(quotation.id) AS countRow FROM quotation WHERE company_name = '$companyName'";
$countRes = mysqli_query($connect, $countQuery);
while($countRow = mysqli_fetch_assoc($countRes)){
$count = $countRow['countRow'];
}
$quoteNum = $companyName . ' - ' .$count;
$sqlDate = $row['date'];
$date = strtotime($sqlDate);
$date = date('j F Y', $date);
$output .= "
<div class='row'>
<div class='col'>
<img class='logo' src='img/logo.jpg'>
</div>
</div>
<div class='row margin'>
<div class='col'>
<strong><h3>To:" . $companyName . "</h3>
Email:". $email."</strong>
</div>
</div>
<div class='row margin'>
<div class='col'>Quotation Number:". $quoteNum ."</div>
</div>
<div class='row'>
<div class='col'>Issue Date:". $date ."</div>
</div>
<div class='row margin'>
<div class='col'>
<p>Further to your enquiry, please find attached our quotation based on your discussed requirements. If you have any other queries, amendments or your requirements change please do not hesitate to contact me.</p>
<p>Thank you for the opportunity to quote on this project.</p>
</div>
</div>
<div class='row margin'>
<div class='col'>
<h1>Your quotation:</h1>
<table class='table table-bordered table-striped table-condensed table-responsive'>
<thead>
<tr>
<th>
Quote Details
</th>
<th class='float-right'>
Amount Quoted
</th>
</tr>
</thead>
<tbody>";
$query = "SELECT * FROM quote_list, quotation WHERE quote_list.quote_id = quotation.id AND quote_list.quote_id = '$quote'";
$result = mysqli_query($connect, $query);
$total = 0;
$discount = 0;
while($row = mysqli_fetch_assoc($result)){
$title = $row['title'];
$price = $row['price'];
$discount = $row['discount'];
$total += $price;
$ouput .=
"
<tr>
<td>".
$title."
</td>
<td class='float-right'>
£".$price.
"
</td>
</tr>
";
}
$final = $total-$discount;
$output .= "
<tr>
<td></td>
<td class='float-right'><em><strong>Total: </strong></em>£".$total."</br><em><strong>Discount: </strong></em>£".$discount."</br><em><strong>Quotation Price: </strong></em>£".$final."</td>
</tr>
</tbody>
</table>
</div>
</div>
<div class='row margin'>
<div class='col'>
<h1>Terms and Conditions</h1>
<h2>Our Quotation</h2>
<p>The above costs are inclusive of VAT, which will be charged where applicable. NI Flyers Print & Design quotations are valid for 30 days. Design costs are based on our understanding of your initial brief. Any additional amends/change to brief will be advised prior to invoicing. The right of design creations remains exclusively with NI Flyers Print & Design including economic and moral rights. Acceptance of this quotation includes a non-exclusive licence for the use of the works outlined above. An exclusive licence may be obtained at an additional cost.</p>
<h2>Additional photographic or illustration-based imagery</h2>
<p>Sourced photography or illustration this will be an additional cost to the design process. Imagery can be sourced either from stock library at £30.00 per image, or commissioned at cost, which will always be pre-quoted. If attendance to manage or art direct photoshoots is required this will be based on our standard hourly rate of £50 per hour. Additional photoshoot props or services will be charged accordingly.</p>
</div>
</div>
";
}
return $output;
}
if(isset($_GET['viewPDF'])){
require_once('tcpdf/tcpdf.php');
$obj_pdf = new TCPDF('P', PDF_UNIT, PDF_PAGE_FORMAT, true, 'UTF-8', false);
$obj_pdf->SetCreator(PDF_CREATOR);
$obj_pdf->SetTitle("Generate HTML Table Data To PDF From MySQL Database Using TCPDF In PHP");
$obj_pdf->SetHeaderData('', '', PDF_HEADER_TITLE, PDF_HEADER_STRING);
$obj_pdf->setHeaderFont(Array(PDF_FONT_NAME_MAIN, '', PDF_FONT_SIZE_MAIN));
$obj_pdf->setFooterFont(Array(PDF_FONT_NAME_DATA, '', PDF_FONT_SIZE_DATA));
$obj_pdf->SetDefaultMonospacedFont('helvetica');
$obj_pdf->SetFooterMargin(PDF_MARGIN_FOOTER);
$obj_pdf->SetMargins(PDF_MARGIN_LEFT, '10', PDF_MARGIN_RIGHT);
$obj_pdf->setPrintHeader(false);
$obj_pdf->setPrintFooter(false);
$obj_pdf->SetAutoPageBreak(TRUE, 10);
$obj_pdf->SetFont('helvetica', '', 11);
$obj_pdf->AddPage();
$output .= fetchData();
$obj_pdf->writeHTML($output);
$obj_pdf->Output('Quote_' . $quote . '.pdf', 'I');
}
?>
我在制作这份文件时是否做错了什么?我正在关注这方面的教程和文档,但似乎根本无法加载它。由于某种原因总是一个空白的 PDF 文档。通过 PHP 动态创建 PDF 时,是否可以使用更简单的工具?
最佳答案
您的 fetchData() 函数似乎没有返回任何内容。
如果我修改:
$obj_pdf->writeHTML($output);
阅读..
$obj_pdf->writeHTML('hello world');
然后这会正确显示在 PDF 中。这似乎可以确认您的 TCPDF 代码是正确的。
当我在本地运行您的代码时,您的 fetchData() 函数没有返回任何内容。显然我没有你的数据库设置,但我认为这就是你的问题所在。
尝试在整个函数中添加一些 echo ,并确保返回您认为要返回的内容。
关于php - 使用 TCPDF 从服务器中提取动态数据并显示为 PDF,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47275937/
我正在做一个业余爱好项目,使用 Ruby、PHP 或 Java 来抓取 ASP.net 网站的内容。例如,如果网站 url“www.myaspnet.com/home.aspx”。我想从 home.a
如果我有这些字符串: mystrings <- c("X2/D2/F4", "X10/D9/F4", "X3/D22/F4",
我有以下数据集 > head(names$SAMPLE_ID) [1] "Bacteria|Proteobacteria|Gammaproteobacteria|Pseudomonadales|Mor
设置: 3个域类A,B和C。A和B在插件中。 C在依赖于此插件的应用程序中。 class A{ B b static mapping = { b fetch: 'joi
我不知道如何提取 XML 文件中的开始标记元素名称。我很接近〜意味着没有错误,我正在获取标签名称,但我正在获取标签名称加上信息。我得到的是: {http://www.publishing.org}au
我有一个字符串 x <- "Name of the Student? Michael Sneider" 我想从中提取“Michael Sneider”。 我用过: str_extract_all(x,
我有一个如下所示的文本文件: [* content I want *] [ more content ] 我想读取该文件并能够提取我想要的内容。我能做的最好的事情如下,但它会返回 [更多内容] 请注意
假设我有一个项目集合 $collection = array( 'item1' => array( 'post' => $post, 'ca
我正在寻找一种过滤文本文件的方法。我有许多文件夹名称,其中包含许多文本文件,文本文件有几个没有人员,每个人员有 10 个群集/组(我在这里只显示了 3 个)。但是每个组/簇可能包含几个原语(我在这里展
我已经编写了一个从某个网页中提取网址的代码,我面临的问题是它不会以网页上相同的方式提取网址,我的意思是如果该网址位于某些网页中法语,它不会按原样提取它。我该如何解决这个问题? import reque
如何在 C# 中提取 ZipFile?(ZipFile 是包含文件和目录) 最佳答案 为此使用工具。类似于 SharpZip .据我所知 - .NET 不支持开箱即用的 ZIP 文件。 来自 here
我有一个表达: [training_width]:lofmimics 我要提取[]之间的内容,在上面的例子中我要 training_width 我试过以下方法: QRegularExpression
我正在尝试创建一个 Bash 脚本,该脚本将从命令行给出的最后一个参数提取到一个变量中以供其他地方使用。这是我正在处理的脚本: #!/bin/bash # compact - archive and
我正在寻找一个 JavaScript 函数/正则表达式来从 URI 中提取 *.com...(在客户端完成) 它应该适用于以下情况: siphone.com = siphone.com qwr.sip
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 8 年前。 Improve this qu
编辑:添加了实际的 JSON 对象和代码以供审查 我有这种格式的 JSON(只是这种层次结构,假设 JSON 正常工作) {u'kind': u'calendar#events', u'default
我已经编写了代码来使用 BeautifulSoup 提取一本书的 url 和标题来自页面。 但它并没有在 > 之间提取惊人的 super 科学故事 1930 年 4 月这本书的名字。和 标签。 如何提
使用 Java,我想提取美元符号 $ 之间的单词。 例如: String = " this is first attribute $color$. this is the second attribu
您好,我正在尝试找到一种方法来确定字符串中的常量,然后提取该常量左侧的一定数量的字符。 例如-我有一个 .txt 文件,在那个文件的某处有数字 00nnn 数字的例子是 00234 00765 ...
php读取zip文件(删除文件,提取文件,增加文件)实例 从zip压缩文件中提取文件 复制代码 代码如下: <?php /* php 从zip压缩文件
我是一名优秀的程序员,十分优秀!