php – 如何从ajax数据发送(使用jsPDF)将pdf上传到服务器
发布时间:2020-12-13 18:17:27 所属栏目:PHP教程 来源:网络整理
导读:我正在使用jsPDF在客户端生成pdf.使用doc.save(‘filename.pdf’)函数,我可以下载它. 现在我需要将它保存在服务器上,所以我用.ajax()发送pdf数据并用 PHP脚本接收它,但生成的pdfURL上的图像没有显示( http://mydomain/tmp/test.pdf);只显示文字. 你可以帮我
我正在使用jsPDF在客户端生成pdf.使用doc.save(‘filename.pdf’)函数,我可以下载它.
现在我需要将它保存在服务器上,所以我用.ajax()发送pdf数据并用 PHP脚本接收它,但生成的pdfURL上的图像没有显示( http://mydomain/tmp/test.pdf);只显示文字. 你可以帮我一把吗? 我的js代码: //doc.save('test.pdf'); WORKS WELL var pdf = doc.output(); $.ajax({ method: "POST",url: "inc/test.php",data: {data: pdf},}).done(function(data){ console.log(data); }); PHP脚本: <?php if(!empty($_POST['data'])){ $data = $_POST['data']; print_r($data); file_put_contents( "../tmp/test.pdf",$data ); } else { echo "No Data Sent"; } exit(); ?> 这是php脚本过程后生成的pdf: 这是使用doc.save()函数生成的:
解:
我试图将pdf数据作为二进制文件发送.我只是base64编码字符串,发送它,他们在PHP上解码. JS: var pdf = btoa(doc.output()); $.ajax({ method: "POST",}).done(function(data){ console.log(data); }); PHP: if(!empty($_POST['data'])){ $data = base64_decode($_POST['data']); // print_r($data); file_put_contents( "../tmp/test.pdf",$data ); } else { echo "No Data Sent"; } exit(); (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |