2010-08-20 251 views
3

我正在使用TCPDF生成PDF,我想將生成的PDF作爲blob保存在MySQL數據庫中。我應該將哪些數據保存到數據庫? 代碼的PDF頁面PHP MySQL:將PDF保存到數據庫

<?php 
require_once('../config/lang/eng.php'); 
require_once('../tcpdf.php'); 

// create new PDF document 
$pdf = new TCPDF(PDF_PAGE_ORIENTATION, PDF_UNIT, PDF_PAGE_FORMAT, true, 'UTF-8', false); 

// set document information 
$pdf->SetCreator(PDF_CREATOR); 
$pdf->SetAuthor('Nicola Asuni'); 
$pdf->SetTitle('TCPDF Example 001'); 
$pdf->SetSubject('TCPDF Tutorial'); 
$pdf->SetKeywords('TCPDF, PDF, example, test, guide'); 

// set default header data 
$pdf->SetHeaderData(PDF_HEADER_LOGO, PDF_HEADER_LOGO_WIDTH, PDF_HEADER_TITLE.' 001', PDF_HEADER_STRING); 

// set header and footer fonts 
$pdf->setHeaderFont(Array(PDF_FONT_NAME_MAIN, '', PDF_FONT_SIZE_MAIN)); 
$pdf->setFooterFont(Array(PDF_FONT_NAME_DATA, '', PDF_FONT_SIZE_DATA)); 

// set default monospaced font 
$pdf->SetDefaultMonospacedFont(PDF_FONT_MONOSPACED); 

//set margins 
$pdf->SetMargins(PDF_MARGIN_LEFT, PDF_MARGIN_TOP, PDF_MARGIN_RIGHT); 
$pdf->SetHeaderMargin(PDF_MARGIN_HEADER); 
$pdf->SetFooterMargin(PDF_MARGIN_FOOTER); 

//set auto page breaks 
$pdf->SetAutoPageBreak(TRUE, PDF_MARGIN_BOTTOM); 

//set image scale factor 
$pdf->setImageScale(PDF_IMAGE_SCALE_RATIO); 

//set some language-dependent strings 
$pdf->setLanguageArray($l); 

// --------------------------------------------------------- 

// set default font subsetting mode 
$pdf->setFontSubsetting(true); 

// Set font 
// dejavusans is a UTF-8 Unicode font, if you only need to 
// print standard ASCII chars, you can use core fonts like 
// helvetica or times to reduce file size. 
$pdf->SetFont('dejavusans', '', 14, '', true); 

// Add a page 
// This method has several options, check the source code documentation for more information. 
$pdf->AddPage(); 

// Set some content to print 
$html = <<<EOD 
<h1>Welcome to <a href="http://www.tcpdf.org" style="text-decoration:none;color:black;"><span style="background-color:#CC0000;"> TC<span style="color:white;">PDF</span> </span></a>!</h1> 
<i>This is the first example of TCPDF library.</i> 
<p>This text is printed using the <i>writeHTMLCell()</i> method but you can also use: <i>Multicell(), writeHTML(), Write(), Cell() and Text()</i>.</p> 
<p>Please check the source code documentation and other examples for further information.</p> 
<p style="color:#CC0000;">TO IMPROVE AND EXPAND TCPDF I NEED YOUR SUPPORT, PLEASE <a href="http://sourceforge.net/donate/index.php?group_id=128076">MAKE A DONATION!</a></p> 
EOD; 

// Print text using writeHTMLCell() 
$pdf->writeHTMLCell($w=0, $h=0, $x='', $y='', $html, $border=0, $ln=1, $fill=0, $reseth=true, $align='', $autopadding=true); 

// --------------------------------------------------------- 

// Close and output PDF document 
// This method has several options, check the source code documentation for more information. 
$pdf->Output('example_001.pdf', 'I'); 

//============================================================+ 
// END OF FILE 
//============================================================+ 
?> 

代碼輸出的PDF文件瀏覽器。我如何將pdf數據保存到數據庫或以其他方式保存到文件系統?對於文本數據,我已經使用file_put_contents來創建html/txt文件。

解決了感謝Piskvor。 解決方案代碼

$content=$pdf->Output('', 'S'); 
header("Content-type:application/pdf"); 
header("Content-Disposition:attachment;filename='pdf.pdf'"); 
echo $content; 

可以節省$內容在您的分貝斑點和檢索它來生成PDF文件。如果您希望在瀏覽器中打開pdf,請刪除以下行。

header(「Content-Disposition:attachment; filename ='pdf.pdf'」);

+0

你的問題是什麼?另外,你確定這是一個好主意嗎? – 2010-08-20 09:21:15

+1

相關:http://stackoverflow.com/questions/3748/storing-images-in-db-yea-or-nay – 2010-08-20 09:21:36

+0

我明白,存儲blob可能不是一個好主意,但將pdf存儲到文件系統意味着在備份期間也必須管理pdf發票文件夾。將它存儲爲blob意味着我有一件事情可以管理。 – abel 2010-08-20 09:28:27

回答

6

答案就在那裏,在你的代碼:

// Close and output PDF document 
// **This method has several options**, check the source code documentation for more information. 
$pdf->Output('example_001.pdf', 'I'); 

From the documentation

參數:(...) 字符串$ dest目標在哪裏發送 文件。它可以採用以下值之一的 :(...)S:將文檔作爲 字符串返回。名稱被忽略。

於是,從而改變你的代碼:

$pdffilecontent = $pdf->Output('', 'S'); 

而該字符串保存到數據庫

+0

謝謝。我試過沒有'S'選項。 – abel 2010-08-20 09:38:42

+0

@abel:不客氣。 – Piskvor 2010-08-20 10:00:43

3

輸出($名= 'example_001.pdf',$ DEST = 'I')

在$ DEST字符串(目的地,發送文件)

的值可以是:

I: send the file inline to the browser (default). 
D: send to the browser and force a file download with the name given by name. 
F: save to a local server file with the name given by name. 
S: return the document as a string (name is ignored). 
FI: equivalent to F + I option 
FD: equivalent to F + D option 
E: return the document as base64 mime multi-part email attachment (RFC 2045) 

希望有所幫助!

+0

謝謝..它幫助我很多 – CodeSlayer 2014-07-30 01:39:00