使用html2pdf保存PDF

问题描述 投票:0回答:1

我正在使用html2pdf生成pdf文件。我想将这些文件保存在磁盘的后台。我使用带有参数“datauri”的html2pdf.outputPdf(jsPDF.output)来进行64位编码。

然后我在我的PHP脚本中解码它们并保存它们。当我尝试在我的文件夹中打开生成的文件时,我从adobe收到文件已损坏的消息(可能没有正确解码)。

为什么会发生这种情况,我该如何解决?

使用Javascript:

<script>

$(document).ready(function() {

$('#Save').on('click', function () {

  element = document.getElementById('root');

  var pdf;
  var pdfout;
  var Narvarande = "Johnny";
  var filnamn = "123456";
  var Lagenhetsadress = "BB1234 43";

  //html2pdf().from(element).save();
  //console.log("CLicked!");

  html2pdf().from(element).outputPdf('datauri').then(function(pdfout){

//  console.log(btoa(pdf));;

  $.ajax({
    method: "POST",
    url: "includes/skickapdf.php",
    data: {
      data: pdfout,
      besiktare: Narvarande,
      namn: filnamn,
      adress: Lagenhetsadress,
    },
  }).done(function(data){
    console.log("Return från skickapdf: ");
  console.log(data);
});

});

  });
});

</script>

PHP:

<?php
if(!empty($_POST['data']) && isset($_POST['namn']) &&isset($_POST['besiktare'])&& isset($_POST['adress']))
{

  $N = $_POST['namn'];
  $B = $_POST['besiktare'];
  $A = $_POST['adress'];

  $data = base64_decode($_POST['data']);
  echo ($N);
  // print_r($data);
  file_put_contents("{$N}.pdf", $data);
} 
else {
  echo "No Data Sent";
  echo "--------------";
  echo $_POST['data'];
  echo "--------------";
}``
?>
javascript php ajax encoding html2pdf
1个回答
0
投票

如果你只是想把你的html保存为本地的pdf,你可能想要使用jsPDF的.html()html2canvas 1.0.0-alpha.12,而不是html2pdf

<script src="https://cdnjs.cloudflare.com/ajax/libs/jspdf/1.5.3/jspdf.debug.js" 
        integrity="sha384-NaWTHo/8YCBYJ59830LTz/P4aQZK1sS0SneOgAvhsIl3zBu8r9RevNg5lHCHAuQ/"
        crossorigin="anonymous"></script>
<script src="https://html2canvas.hertzen.com/dist/html2canvas.min.js"></script>
<!-- html2canvas 1.0.0-alpha.11 or higher version is needed -->

<script>
    function onClick() {
        let pdf = new jsPDF('p', 'pt', 'letter');
        pdf.html(document.body, {
            callback: function () {
                pdf.save('test.pdf');
                window.open(pdf.output('bloburl')); // To debug.
            }
        });
    }
</script>
© www.soinside.com 2019 - 2024. All rights reserved.