我在将JSON数据输出到PDF所需的类时遇到了问题。 PHP文件如下:
<?php
header('Content-type: text/json');
ob_start();
require('fpdf.php');
class PDF extends FPDF{
// Colored table
function FancyTable($PDFtabHead, $PDFtabData)
{
// stuff with table works if tested with another PHP page
}
} // END -class
$PDFtabHead = json_decode(($_POST['PDFtabHead']), true);
$PDFtabData = json_decode(($_POST['PDFtabData']), true);
$pdf = new PDF();
$pdf->SetFont('Arial','',12);
$pdf->AddPage();
$pdf->FancyTable($PDFtabHead,$PDFtabData);
$pdf->Output();
echo json_encode(array("res"=>$PDFtabHead)); // Only to chek if outputs something
ob_end_flush();
?>
我的JS文件中的调用函数是:
$.ajax({
type: "POST",
async: false,
url: './FPDF/PDF.php',
dataType: 'json',
data: {PDFtabHead: tabHead, PDFtabData: tabData},
success: function (response) {
var res = response.res;
console.log("ok return: "+res);
} // success
,
error: function() {
console.log("ERROR CONNECTING TO ./FPDF/PDF.php");
}// error
}); // ajax
tabHead 和 tabData 是正确的,这是tabData的输出:
[“05:22”,“0043”,“22:31”,“200201”,“05:22”,“0044”,“22:31”,......]
对PDF.php的调用总是以错误结束,输出到控制台:ERROR CONNECTING TO ./FPDF/PDF.php
如果我从另一个不以JSON格式发送数据的测试页面测试它,而是正常的PHP数组,它可以工作。显然我必须改为
$PDFtabHead = ($_POST['PDFtabHead']);
$PDFtabData = ($_POST['PDFtabData']);
在这种情况下,PDF页面会正确呈现。
同样,如果我删除类声明,只需返回我的JS页面JSON数组,它就可以工作;不打印PDF很清楚,但数组按预期返回
答案 0 :(得分:0)
好的,我已经在FPDF论坛上找到了解决方案 http://www.fpdf.org/?go=forum&i=56364&t=56363,奥利弗的回答是
不要从AJAX通话中返回PDF。