首页 >web前端 >js教程 >如何在使用 PHP 和 AJAX 创建后强制下载 CSV 文件?

如何在使用 PHP 和 AJAX 创建后强制下载 CSV 文件?

Susan Sarandon
Susan Sarandon原创
2024-10-24 08:35:02838浏览

How to Force Download a CSV File After Creation with PHP and AJAX?

如何在 PHP 中通过 AJAX 下载文件

在使用 Web 应用程序时,通常需要从服务器下载文件。 AJAX(异步 JavaScript 和 XML)提供了一种无需重新加载页面即可启动此类下载的方法。

一种方法涉及创建一个触发 AJAX 功能的按钮。以下代码片段演示了这种方法:

<code class="php">function csv(){
  $ajaxRequest = ajax();
  $postdata = "data=" . document.getElementById("id").value;
  $ajaxRequest.onreadystatechange = function(){
    var ajaxDisplay = document.getElementById('ajaxDiv');
    if($ajaxRequest.readyState == 4 && $ajaxRequest.status==200){
      ajaxDisplay.innerHTML = $ajaxRequest.responseText;           
    }
  }

  $ajaxRequest.open("POST","csv.php",false);
  $ajaxRequest.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
  $ajaxRequest.send($postdata);
}</code>

但是,这里的问题是如何在 PHP 创建 CSV 文件后强制下载该文件。 PHP 文件中提供的脚本如下:

<code class="php">$fileName = 'file.csv';
$downloadFileName = 'newfile.csv';

if (file_exists($fileName)) {
  header('Content-Description: File Transfer');
  header('Content-Type: text/csv');
  header('Content-Disposition: attachment; filename='.$downloadFileName);
  ob_clean();
  flush();
  readfile($fileName);
  exit;
}
echo "done";</code>

问题是运行此脚本不会启动下载,而是在页面内(ajaxDiv 内)显示 CSV 文件的内容.

这个问题的答案是AJAX 不适用于文件下载。相反,最佳做法是打开一个新窗口并将其地址设置为下载链接。或者,您可以使用 document.location = .....

直接将页面重定向到下载链接

以上是如何在使用 PHP 和 AJAX 创建后强制下载 CSV 文件?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn