Как скачать файл Excel в браузере Internet Explorer с библиотекой phpexcel - PullRequest
1 голос
/ 14 мая 2011

Я написал код, который работает в Mozilla Firefox, но не работает в Internet Explorer, я не могу решить его.в Internet Explorer его полная страница без всплывающей загрузки.Мне нужно создать файл Excel с поддержкой IE также. Пожалуйста, помогите мне.

вот мой код.


$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;

Ответы [ 2 ]

1 голос
/ 30 мая 2012

Это полный заголовок использования решения ('Pragma:');

0 голосов
/ 15 февраля 2018

Ваша проблема связана с отсутствующими заголовками.

Попробуйте заменить код заголовка следующим кодом:

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');
...