php – 如何从ajax数据发送(使用jsPDF)将pdf上传到服务器

前端之家收集整理的这篇文章主要介绍了php – 如何从ajax数据发送(使用jsPDF)将pdf上传到服务器前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在使用jsPDF在客户端生成pdf.使用doc.save(‘filename.pdf’)函数,我可以下载它.
现在我需要将它保存在服务器上,所以我用.ajax()发送pdf数据并用 PHP脚本接收它,但生成的pdfURL上的图像没有显示( http://mydomain/tmp/test.pdf);只显示文字. @H_404_2@你可以帮我一把吗?

@H_404_2@我的js代码

  1. //doc.save('test.pdf'); WORKS WELL
  2. var pdf = doc.output();
  3. $.ajax({
  4. method: "POST",url: "inc/test.PHP",data: {data: pdf},}).done(function(data){
  5. console.log(data);
  6. });
@H_404_2@PHP脚本:

  1. <?PHP
  2. if(!empty($_POST['data'])){
  3.  
  4. $data = $_POST['data'];
  5. print_r($data);
  6.  
  7. file_put_contents( "../tmp/test.pdf",$data );
  8. } else {
  9. echo "No Data Sent";
  10. }
  11. exit();
  12. ?>
@H_404_2@这是PHP脚本过程后生成的pdf:
http://control.edge-cdn.com.ar/tmp/test.pdf

@H_404_2@这是使用doc.save()函数生成的:
http://control.edge-cdn.com.ar/repo/all.pdf
问候!

解: @H_404_2@我试图将pdf数据作为二进制文件发送.我只是base64编码字符串,发送它,他们在PHP上解码.

@H_404_2@JS:

  1. var pdf = btoa(doc.output());
  2. $.ajax({
  3. method: "POST",}).done(function(data){
  4. console.log(data);
  5. });
@H_404_2@PHP

  1. if(!empty($_POST['data'])){
  2. $data = base64_decode($_POST['data']);
  3. // print_r($data);
  4. file_put_contents( "../tmp/test.pdf",$data );
  5. } else {
  6. echo "No Data Sent";
  7. }
  8. exit();

猜你在找的PHP相关文章