1、后台生成数据流 post提交
$objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');
ob_start();
$objWriter->save('php://output');
$xlsData = ob_get_contents();
ob_end_clean();
$data = [
'file' => "data:application/vnd.ms-excel;base64," . base64_encode($xlsData),
'name' => $filename
];
return $this->success($data);
前端下载
以Fastadmin 后台 ajax调取为例
Fast.api.ajax({
url: "/admin/student/student/daochuExcel",
data:{filter:filter,ids:ids},
}, function(redata,res){
//成功的回调
var $a = $("<a>");
$a.attr("href", res.msg.file);
$a.attr("download", res.msg.name);
$("body").append($a);
$a[0].click();
$a.remove();
alert('下载成功,请等待');
return false;
});
2、后台直接生成文件下载 get方式提交
$objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');
ob_end_clean();
header("Content-Type: application/force-download");
header("Content-Type: application/octet-stream");
header("Content-Type: application/download");
header('Content-Disposition:inline;filename="' . $filename . '.xls"');
header("Content-Transfer-Encoding: binary");
header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT");
header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
header("Pragma: no-cache");
$objWriter->save('php://output');