2

所以我有一个页面,用户将点击“导出”按钮,我想运行一个 javascript 函数并获取导出所需的数据,然后调用 php 脚本从我的数据库中获取数据并强制下载。现在的问题是,我可以运行 javascript,然后在我的脚本中调用一个帖子,但没有下载任何内容。我假设这是因为我实际上并没有将窗口移动到 php 文件,我只是在调用脚本。谁能帮我吗?

javascript: ids 是一个数组,我需要传递它来获取信息。这是当用户点击“导出”按钮时我调用的函数内部。

$.ajax({        
   type: "POST",
   url: "exportLeads.php",
   data: { 'idArray' : ids }
}); 

php:我使用这个Export to CSV via PHP quetsion。该功能已正确实现,我没有收到任何错误。只是没有提示下载的文件。

$data = mysql_query($query) or die($query.mysql_error());
$results = array();
while($line = mysql_fetch_array($data, MYSQL_ASSOC)){
    $results[] = $line;
}
download_send_headers("data_export_" . date("Y-m-d") . ".csv");
echo array2csv($results);
die();
4

3 回答 3

1

您无法使用 ajax 下载文件。您可以使用window.location.href将用户重定向到文件位置,但是无论如何,我建议您阅读此内容,有人会为您提供更好的答案:)

通过 jQuery.Ajax 下载文件

或者你也可以在你的javascript中使用这样的东西

$.post( "exportLeads.php", { 'idArray' : ids }, function( response ) {
  if ( response.error === 0 ) {
    window.location.href  = response.location;
  }
}, "json" );

在你的 php 文件中

<?php
  if ( $has_error ) {
    echo json_encode( array( "error" => 1 ) );
  }
  else {
    echo json_encode( array(
      "error"     =>  0,
      "location"  =>  "link_to_file"
    ) );
  }
?>
于 2013-07-06T18:58:37.573 回答
1

没有时间编写代码,但简而言之,您需要:

  • 执行JS通过ajax调用服务器端。
  • 生成文件,用一些随机名称将其放入服务器驱动器。在会话中记住该名称。向客户发送一些响应。
  • 当客户端得到响应时,使用 JS 将用户重定向到某个页面,PHP 代码检查会话中是否有某个文件名,如果有,则读取该文件,从会话中删除它及其名称。
于 2013-07-06T18:54:54.707 回答
0

您可以在成功功能中使用 window.location.href :

$.ajax({
     type: "POST",
     dataType: "json",
     url: "exportLeads.php",
     data: { 'idArray' : ids },
     success: function(data) {
          if (data.success) window.location.href = "/link-to-your-download-script";
     }
}); 

您必须更改对 json_encode 的响应并将功能拆分为两个脚本,一个用于导出,一个用于下载脚本(具有唯一的 id 或某事。)

于 2013-07-06T18:51:59.617 回答