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(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。