从AJAX调用下载PHP输出缓冲区内置的文件

Das*_*Rot 6 php ajax jquery download output

我正在尝试用PHP构建一个CSV文件,然后从AJAX调用中调用PHP文件,然后在AJAX调用成功后启动CSV文件的下载.如果我在服务器上保存.csv的物理副本,这可以正常工作,但我想使用,php://ouput所以我不必担心物理文件堵塞服务器.是否可以从返回php://outputAJAX 开始下载?这是我的代码:

HTML/jQuery的:

<!DOCTYPE html>

<html lang="en">
    <head>
        <meta charset="utf-8" />
        <script type="text/javascript" language="javascript" src="jquery.js"></script>
        <script type="text/javascript">
             $("#download").live("click", function() {
                var request = $.ajax({
                    dataType: 'html',
                    url: 'php.php',
                    success: function(response) {
                        alert('Finished');
                    }
                })
            })
        </script>
    </head>
    <body>
        <h1 id="download">DOWNLOAD</h1>
    </body>
</html>
Run Code Online (Sandbox Code Playgroud)

PHP:

<?php 
    header('Content-type: application/vnd.ms-excel');
    header('Content-disposition: attachment; filename="test.csv"');
    $f = fopen('php://output', 'w');
    fwrite($f,'this,is,a,test');
    fclose($f);
    readfile('php://output');
    return;
?>
Run Code Online (Sandbox Code Playgroud)

我不知道如何从我的AJAX调用返回文件保存对话框.

这必须简单,但我似乎找不到任何结合这两个问题的例子.

Das*_*Rot 1

下面的代码可以工作,但是效率很低,因为它调用了 php.php 文件两次。有人有更好的想法吗?

<!DOCTYPE html>

<html lang="en">
    <head>
        <meta charset="utf-8" />
        <script type="text/javascript" language="javascript" src="jquery.js"></script>
        <script type="text/javascript">
             $("#download").live("click", function() {
                var request = $.ajax({
                    dataType: 'html',
                    url: 'php.php',
                    success: function(response) {
                        window.open('php.php');
                    }
                })
            })
        </script>
    </head>
    <body>
        <h1 id="download">DOWNLOAD</h1>
    </body>
</html>
Run Code Online (Sandbox Code Playgroud)

无论如何,是否只为这个实例缓存“php.php”,以便它在 下立即加载window.open('php.php'),但当我单击download“下一步”时会重新加载内容?

为什么window.open(response)效果不一样?