PHP使用ajax的post方式下载excel文件简单示例
本文实例讲述了PHP使用ajax的post方式下载excel文件。分享给大家供大家参考,具体如下:
项目需求,前端发起ajax请求,后端生成excel并下载,同时需要在header头中,带上token验证信息,参考了很多文章,最终实现如下:
PHP后端使用base64:
$filename='demo.xlsx';
$objWriter=\PHPExcel_IOFactory::createWriter($objectPHPExcel,'Excel2007');
ob_start();
$objWriter->save("php://output");
$xlsData=ob_get_contents();
ob_end_clean();
returnApi::success(['filename'=>$filename,'file'=>"data:application/vnd.ms-excel;base64,".base64_encode($xlsData)]);
JS前端:
$('.download').click(function(){
varurl="http://xxxx.com/group/bi/export";
varparams={
from_date:'2017-09-01',
to_date:'2017-09-08',
group_id:1
};
$.ajax({
type:'POST',
url:url,
data:params,
beforeSend:function(request){
request.setRequestHeader("Authorization","token信息,验证身份");
},
success:function(redata){
//创建a标签,设置属性,并触发点击下载
var$a=$("");
$a.attr("href",redata.data.file);
$a.attr("download",redata.data.filename);
$("body").append($a);
$a[0].click();
$a.remove();
}
});
});
更多关于PHP相关内容可查看本站专题:《PHP+ajax技巧与应用小结》、《php操作office文档技巧总结(包括word,excel,access,ppt)》、《PHP网络编程技巧总结》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家PHP程序设计有所帮助。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。