phpexcel 库在本地主机上工作正常但在服务器中生成空白 excel 文件

phpexcel library works fine on localhost but generates blank excel file in server

这是我的代码,它在本地主机上运行良好,可以生成一个包含数据库数据的 excel 文件,但在托管服务器中它会生成一个空白的 excel 文件:

// Starting the PHPExcel library
            $this->load->library('PHPExcel');
            //$this->load->library('PHPExcel/IOFactory');

            $objPHPExcel = new PHPExcel();
            $objPHPExcel->getProperties()->setTitle("export")->setDescription("none");
            $objPHPExcel->setActiveSheetIndex(0);

            // Field names in the first row
            $fields = $query->list_fields();
            $col = 0;
            foreach ($fields as $field)
            {
                $objPHPExcel->getActiveSheet()->setCellValueByColumnAndRow($col, 1, $field);
                $col++;
            }

            //format the column sizes 
            $sheet = $objPHPExcel->getActiveSheet();
            $cellIterator = $sheet->getRowIterator()->current()->getCellIterator();
            $cellIterator->setIterateOnlyExistingCells( true );
            /** @var PHPExcel_Cell $cell */
            foreach( $cellIterator as $cell ) {
                    $sheet->getColumnDimension( $cell->getColumn() )->setAutoSize( true );
            }

            //var_dump($query->result());
            //die;

            // Fetching the table data
            $row = 2;
            foreach($query->result() as $data)
            {
                $col = 0;
                foreach($fields as $field)
                {
                    $objPHPExcel->getActiveSheet()->setCellValueByColumnAndRow($col, $row, $data->$field);
                    $col++;
                }

                $row++;
            }

            $objPHPExcel->setActiveSheetIndex(0);
            $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');


            header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
            header('Content-Disposition: attachment;filename="01simple.xlsx"');
            header('Cache-Control: max-age=0');

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

我认为问题与phpexcel无关。我之前遇到过类似的问题,后来发现 CI 的 list_fields() 函数在某些 linux 服务器上不起作用。您可以通过静态放置字段名称而不是使用此函数来检查这方面。