现在,CSV文件将导出到报告文件夹中。相反,我希望浏览器询问导出文件的位置。这样我就可以将文件导出到客户端机器的所需位置,并避免将这些文件存储在服务器(即)报告文件夹中。
$this->load->dbutil();
$this->load->helper('file');
$this->load->helper('download');
$selProducts= $this->db->query("SELECT * FROM tablename");
$data= $this->dbutil->csv_from_result($selProducts);
$randomidgenerated = "reports/".date('Y-m-d').".csv";
if(file_exists(FCPATH.$randomidgenerated)){
$randomidgenerated = "reports/".date('Y-m-d')."_".random_string('alnum', 3).".csv";
}
if ( ! write_file($randomidgenerated, $data))
{
echo 'Unable to write the file';
}
$data = file_get_contents($randomidgenerated);
force_download($randomidgenerated, $data, TRUE);
答案 0 :(得分:1)
从我可以看到你只是创建要动态下载的文件的内容...你现在要做的是强制浏览器将文件下载到客户端选择的部分然后可能删除临时文件如果您不想将其存储在服务器上...在您创建文件或确定其存在之后添加以下代码...类似
$file = FCPATH.$randomidgenerated;
if(file_exists($file)){
header('Content-Description: File Transfer');
header('Content-Type: text/csv');
header('Content-Disposition: attachment; filename='.basename($file));
header('Content-Transfer-Encoding: binary');
header('Expires: 0');
header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
header('Pragma: public');
header('Content-Length: ' . filesize($file));
ob_clean();
flush();
readfile($file);
exit;
}
应该这样做。