2

PHPExcel を Zend2 で動作させようとしています。実際には動作していますが、意図したとおりではありません (ファイルに書き込むことはできますが、保存せずにダウンロードすることはできません)。次のような単純な例をいくつか見つけました。

$objPHPExcel = ....

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

そしてファイルのダウンロードが許可されました。Zend2コントローラーで同様のことを達成するにはどうすればよいですか? 私はこれまでに試しました:

public function generateRaportAction()
{
    $objPHPExcel = new PHPExcel();
    $objPHPExcel->getActiveSheet()->setCellValue( 'B8', 'Some value' );
    $objWriter = \PHPExcel_IOFactory::createWriter( $objPHPExcel, 'Excel5' );

    $response = $this->getEvent()->getResponse();
    $response->getHeaders()->clearHeaders()->addHeaders( array(
        'Pragma' => 'public',
        'Content-Type' => 'application/vnd.ms-excel',
        'Content-Disposition' => 'attachment; filename="test.xls"',
        'Cache-Control' => 'must-revalidate, post-check=0, pre-check=0',
        'Content-Transfer-Encoding' => 'binary',
    ) );
    $objWriter->save( 'php://output' );
    return $response;
}

しかし、それは私のページに「エコーのような」出力を与えます。私の2番目の試みは:

$response->setContent($objWriter->save( 'php://output' ));

それでも結果は同じでした。

4

2 に答える 2