如何使用phpexcel库在internet explorer浏览器中下载excel文件

如何使用phpexcel库在internet explorer浏览器中下载excel文件,php,internet-explorer,download,phpexcel,Php,Internet Explorer,Download,Phpexcel,我编写的代码可以在Mozilla firefox中使用,但不能在internet explorer中使用 我不能解决它。在InternetExplorer中,它的完整页面不带弹出式下载。 我需要与IE支持的generete excel文件也。请帮助我 这是我的密码 $objPHPExcel = new PHPExcel(); $objPHPExcel->getActiveSheet()->getColumnDimension('A')->setWidth(20); $objPHPExcel->

我编写的代码可以在Mozilla firefox中使用,但不能在internet explorer中使用 我不能解决它。在InternetExplorer中,它的完整页面不带弹出式下载。 我需要与IE支持的generete excel文件也。请帮助我

这是我的密码

$objPHPExcel = new PHPExcel(); $objPHPExcel->getActiveSheet()->getColumnDimension('A')->setWidth(20); $objPHPExcel->getActiveSheet()->getColumnDimension('B')->setWidth(18); $objPHPExcel->setActiveSheetIndex(0) ->setCellValue('A1', 'Agent Code') ->setCellValue('B1', 'Month'); $i=2; while($row1=mysql_fetch_array($rs)) { $month = $row1['smonth']+1; $month_name = date( 'F', mktime(0, 0, 0, $month) ); $objPHPExcel->setActiveSheetIndex(0) ->setCellValue('A'.$i, $row1['scode']) ->setCellValue('B'.$i, $month_name) ->setCellValue('C'.$i, $row1['syear']); $i++; } $objPHPExcel->getActiveSheet()->setTitle('Simple'); $objPHPExcel->setActiveSheetIndex(0); header('Content-Type: application/vnd.ms-excel'); header('Content-Disposition: attachment;filename="01simple.xls"'); header('Cache-Control: max-age=0'); $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5'); $objWriter->save('php://output'); exit; $objPHPExcel=new PHPExcel(); $objPHPExcel->getActiveSheet()->getColumnDimension('A')->setWidth(20); $objPHPExcel->getActiveSheet()->getColumnDimension('B')->setWidth(18); $objPHPExcel->setActiveSheetIndex(0) ->setCellValue('A1','Agent Code') ->setCellValue('B1','Month'); $i=2; 而($row1=mysql\u fetch\u数组($rs)) { $month=$row1['smonth']+1; $month_name=日期('F',mktime(0,0,0,$month)); $objPHPExcel->setActiveSheetIndex(0) ->setCellValue('A'.$i,$row1['scode'])) ->setCellValue('B'.$i,$month\u name) ->setCellValue('C'.$i,$row1['syear']); $i++; } $objPHPExcel->getActiveSheet()->setTitle('Simple'); $objPHPExcel->setActiveSheetIndex(0); 标题('Content-Type:application/vnd.ms-excel'); 标题('Content-Disposition:attachment;filename=“01simple.xls”); 标头('Cache-Control:max age=0'); $objWriter=PHPExcel_IOFactory::createWriter($objPHPExcel,'Excel5'); $objWriter->save('php://output'); 出口 这是一个完整的解决方案 使用 标题('Pragma:')

这是一个完整的解决方案 使用
标题('Pragma:')

您的问题与缺少标题有关

尝试用以下代码替换标题代码:

setcookie("fileLoading","true");
// Redirect output to a client’s web browser (Excel2007)
header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
header('Content-Disposition: attachment;filename="'.$viNameFile.'.xlsx"');
header('Cache-Control: max-age=0');
// If you're serving to IE 9, then the following may be needed
header('Cache-Control: max-age=1');

 // If you're serving to IE over SSL, then the following may be needed
 header ('Expires: Mon, 26 Jul 1997 05:00:00 GMT'); // Date in the past
 header ('Last-Modified: '.gmdate('D, d M Y H:i:s').' GMT'); // always modified
 header ('Cache-Control: cache, must-revalidate'); // HTTP/1.1
 header ('Pragma: public'); // HTTP/1.0

 $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');
 $objWriter->save('php://output');

您的问题与缺少标题有关

尝试用以下代码替换标题代码:

setcookie("fileLoading","true");
// Redirect output to a client’s web browser (Excel2007)
header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
header('Content-Disposition: attachment;filename="'.$viNameFile.'.xlsx"');
header('Cache-Control: max-age=0');
// If you're serving to IE 9, then the following may be needed
header('Cache-Control: max-age=1');

 // If you're serving to IE over SSL, then the following may be needed
 header ('Expires: Mon, 26 Jul 1997 05:00:00 GMT'); // Date in the past
 header ('Last-Modified: '.gmdate('D, d M Y H:i:s').' GMT'); // always modified
 header ('Cache-Control: cache, must-revalidate'); // HTTP/1.1
 header ('Pragma: public'); // HTTP/1.0

 $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');
 $objWriter->save('php://output');

丢弃
缓存控件
,添加
内容长度
?某些IE版本在处理被告知不允许缓存的文件下载时反应很差。这是通过ssl连接实现的吗?放弃
缓存控制
,添加
内容长度
?有些IE版本在处理被告知不允许缓存的文件下载时反应不佳。这是通过ssl连接实现的吗?