php ajax生成excel并下载
目标:使用php,通过ajax请求的方式生成一个excel,然后下载。
思路:大致思路是发送一个ajax请求到后台,后台php处理后生成一个excel文件,然后把生成的文件放到一个临时目录,然后把文件链接返回给前端。前端接受到后,然后通过给定的地址,去下载该文件....
代码实现:
前端部分:
<pre name="code" class="html">function outExcel(){
var allSelect = $('._newId:checked').length;
if(allSelect == 0){
layer.msg('请选择需要导出的记录');
return false;
}
var ids = [];
$('._newId:checked').each(function(){
ids.push($(this).val());
});
var params = {id:ids};
$.post("{:U('Home/Saidi/outExcel')}",params,function(res){
if(res.status){
window.location.href = ("{:U('Home/Saidi/download')}?file="+res.url+'&token='+res.token);
}else{
layer.msg('系统错误,操作失败');
}
},'json');
}
其中token是用来做安全校验的.....
后台部分:
使用的是PHPExcel插件。这里用的是TP框架
public function outExcel(){
$ids = I('post.id','','trim');
if(empty($ids)){
exit(json_encode(array('status'=>false,'url'=>'','token'=>'')));
}
$where['id'] = array('in',$ids);
$data = M('news','xyl_')->where($where)->select();
if(!empty($data)){
Vendor('PHPExcel.PHPExcel');
Vendor('PHPExcel.PHPExcel.IOFactory');
$phpExcel = new \PHPExcel();
$phpExcel->setActiveSheetIndex(0)
->setCellValue('A1', '序号')
->setCellValue('B1', '新闻标题')
->setCellValue('C1', '新闻摘要')
->setCellValue('D1', '新闻内容')
->setCellValue('E1', '新闻来源')
->setCellValue('F1', '作者')
->setCellValue('G1', '来源网址');
$len = count($data);
for($i = 0 ; $i < $len ; $i++){
$v = $data[$i];
$rownum = $i+2;
$phpExcel->getActiveSheet()->setCellValue('A' . $rownum, $i);
$phpExcel->getActiveSheet()->setCellValue('B' . $rownum, $v['title']);
$phpExcel->getActiveSheet()->setCellValue('C' . $rownum, $v['summary']);
$phpExcel->getActiveSheet()->setCellValue('D' . $rownum, $v['content']);
$phpExcel->getActiveSheet()->setCellValue('E' . $rownum, $v['from']);
$phpExcel->getActiveSheet()->setCellValue('F' . $rownum, $v['author']);
$phpExcel->getActiveSheet()->setCellValue('G' . $rownum, $v['url']);
}
$phpExcel->setActiveSheetIndex(0);
$filename=date('YmdHis').'.xlsx';
$objWriter=\PHPExcel_IOFactory::createWriter($phpExcel,'Excel2007');
$filePath = C('TMP_PATH').$filename;
$objWriter->save($filePath);
if(!file_exists($filePath)){
$response = array(
'status' => false,
'url' => '',
'token'=>''
);
}else{
$response = array(
'status' => true,
'url' => $filename,
'token'=>$this->getDownLoadToken($filename)
);
}
}else{
$response = array(
'status' => false,
'url' => '',
'token'=>''
);
}
exit(json_encode($response));
}
private function getDownLoadToken($filename,$length = 10){
$str = null;
$strPol = "ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghijklmnopqrstuvwxyz";
$max = strlen($strPol)-1;
for($i=0;$i<$length;$i++){
$str.=$strPol[rand(0,$max)];//rand($min,$max)生成介于min和max两个数之间的一个随机整数
}
$res = md5($str.time());
S($res,$filename);
return $res;
}
public function download(){
$fileName = I('get.file','','trim');
$token = I('get.token','','trim');
if(empty($token) || !S($token)){
header("HTTP/1.0 404 Not Found");
exit;
}
$path = C('TMP_PATH').$fileName;
if(!file_exists($path)){
header("HTTP/1.0 404 Not Found");
exit;
}else{
$file = @fopen($path,"r");
if(!$file){
header("HTTP/1.0 505 Internal server error");
exit;
}
header("Content-type: application/octet-stream");
header("Accept-Ranges: bytes");
header("Accept-Length: ".filesize($path));
header("Content-Disposition: attachment; filename=" . $fileName);
while(!feof($file)){
echo fread($file,2048);
}
fclose($file);
@unlink($path);
S($token,NULL);
exit();
}
}
getDownLoadToken这个方法是用来获取凭证的,也就是token
原文:https://blog.csdn.net/wangyibo5843/article/details/53116717
php ajax生成excel并下载的更多相关文章
- phpexcel生成excel并下载
Loader::import('PHPExcel.Classes.PHPExcel'); // tp5中只需将phpexcel文件放入extend文件夹中,即可采用该方法引入,需要先 use thin ...
- 使用node.js生成excel报表下载(excel-export express篇)
引言:日常工作中已经有许多应用功能块使用了nodejs作为web服务器,而生成报表下载也是我们在传统应用. java中提供了2套类库实现(jxl 和POI),.NET 作为微软的亲儿子更加不用说,各种 ...
- java动态生成excel打包下载
@SuppressWarnings("unchecked") public String batchExport() throws DBException{ @SuppressWa ...
- Asp.net MVC 简单实现生成Excel并下载
由于项目上的需求,需要导出指定条件的Excel文件.经过一翻折腾终于实现了. 现在把代码贴出来分享 (直接把我们项目里面的一部份辅助类的代码分享一下) 我们项目使用的是Asp.Net MVC4.0模式 ...
- 后台生成excel前端下载
后台生成Excel时前端获取下载 Controller控制器: package com.example.test.controller; import com.example.test.common. ...
- ASP.NET网页生成EXCEL并下载(利用DataGrid或GridView等)
前几天要在后台查询数据库内容(用entity framework),将查询出来的信息(List或DataTable形式)转成EXCEL供用户下载.经过谷歌.百度搜索,终于搜出了一些代码.似乎可用了,结 ...
- NPOI生成excel并下载
NPOI文件下载地址:http://npoi.codeplex.com/ 将文件直接引用至项目中即可,,,,, 虽然网上资料很多,但有可能并找不到自己想要的功能,今天闲的没事,所以就稍微整理了一个简单 ...
- 使用ajax的post方式下载excel
项目需求,前端发起ajax请求,后端生成excel并下载,同时需要在header头中,带上token验证信息,参考了很多文章,最终实现如下: PHP后端使用base64: $filename = 'd ...
- .net生成Excel,并下载
生成Excel的方式有很多种,这里记录两个最简单的: 1.将数据保存为html,然后输出到客户端,保存为Excel文件: 2.通过\t\n生成字符串,然后输出到客户端,保存为Excel. 以上两者的原 ...
随机推荐
- Mybatis(下)
Mybatis(下) 一.MaBatis核心配置文件 Mybatis 中文文档 Mybatis 中文文档 1. properties 定义属性及读取属性文件,取的时候用 $(name) ,name 为 ...
- PostgreSQL中的索引(一)
引言 这一系列文章主要关注PostgreSQL中的索引. 可以从不同的角度考虑任何主题.我们将讨论那些使用DMBS的应用开发人员感兴趣的事项:有哪些可用的索引:为什么会有这么多不同的索引:以及如何使用 ...
- python 代码性能分析 库
问题描述 1.Python开发的程序在使用过程中很慢,想确定下是哪段代码比较慢: 2.Python开发的程序在使用过程中占用内存很大,想确定下是哪段代码引起的: 解决方案 使用profile分析分析c ...
- ISO/IEC 9899:2011 条款5——环境
5.环境 1.一个实现在两个不同的数据处理系统环境下分别翻译C源文件与执行C程序,在本国际标准中分别称为翻译环境和执行环境.它们的特征定义并包含了根据顺从标准实现的语法及语义规则所构造的顺从标准的C程 ...
- Spring整合Redis,并配置Jedis连接池
目录 只言片语 创建redis连接池的配置文件 单机版 spring整合redis(使用JedisPool) 项目中使用示例 集群版 spring整合redis(使用JedisCluster) 项目中 ...
- windows下用navicat远程链接虚拟机Linux下MySQL数据库(转)
原文地址:https://www.cnblogs.com/blogforly/p/5997553.html 今天想用navicat远程连接虚拟机中的MySQL数据库,一直连不上,在网上搜索了一下,发现 ...
- (转)自动微分(Automatic Differentiation)简介——tensorflow核心原理
现代深度学习系统中(比如MXNet, TensorFlow等)都用到了一种技术——自动微分.在此之前,机器学习社区中很少发挥这个利器,一般都是用Backpropagation进行梯度求解,然后进行SG ...
- [New!!!]欢迎大佬光临本蒟蒻的博客(2019.11.27更新)
更新于2019.12.22 本蒟蒻在博客园安家啦!!! 本蒟蒻的博客园主页 为更好管理博客,本蒟蒻从今天开始,正式转入博客园. 因为一些原因,我的CSDN博客将彻底不会使用!!!(带来不便,敬请谅解) ...
- LeetCode 13. 罗马数字转整数(Roman to Integer)
13. 罗马数字转整数 13. Roman to Integer 题目描述 罗马数字包含以下七种字符: I,V,X,L,C,D 和 M. 字符 数值 I 1 V ...
- react-native样式里面的一些坑
在我们做react-native项目时,引入css样式之后 控制台报下面的这样的错 解决问题的方法是: 报错的代码 改后的代码