PhpSpreadsheet и PHP 7> ZipArchive :: close не удается создать временный файл - PullRequest
0 голосов
/ 10 июля 2019

На работе мы используем PhpSpreadsheet для создания файла Excel (мы используем его для обеспечения возможности экспорта).

Вот простой код, который я использую (на основе приведенного примера, но PhpSpreadsheet) для генерации файла:

<?php

use PhpOffice\PhpSpreadsheet\IOFactory;
use PhpOffice\PhpSpreadsheet\Spreadsheet;

include_once '../../../libs/includes.inc';

/** @var array $_POST */
$_POST = db::encodeHTMLPost($_POST);

/** @var string $httpReferer */
$httpReferer = $_SERVER['HTTP_REFERER'];

if (strstr($httpReferer, '?')) {

    $httpReferer = explode('?', $httpReferer);
    $httpReferer = $httpReferer[0];
}

try {

    /** @var Spreadsheet $spreadsheet */
    $spreadsheet = new Spreadsheet();


//$spreadsheet = new \PhpOffice\PhpSpreadsheet\Spreadsheet();

// Set the document properties
    $spreadsheet
        ->getProperties()
        ->setCreator('Christina')
        ->setLastModifiedBy('Christina')
        ->setTitle('Test XLSX')
        ->setSubject('Here is the test')
        ->setDescription('Test document for Office 2007 XLSX, generated using PHP classes.')
        ->setKeywords('office 2007 openxml php')
        ->setCategory('Test result file');

    $spreadsheet->setActiveSheetIndex(0)
        ->setCellValue('A1', 'Hello')
        ->setCellValue('B2', 'World')
        ->setCellValue('C1', 'Here')
        ->setCellValue('D2', 'test');

    $spreadsheet->getActiveSheet()->setTitle('A simple test');

    $spreadsheet->setActiveSheetIndex(0);

    // Redirect output to a client’s web browser (Xlsx)
    header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
    header('Content-Disposition: attachment;filename="01simple.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


    $writer = new \PhpOffice\PhpSpreadsheet\Writer\Xlsx($spreadsheet);
    $writer->save('php://output');

    exit;

} catch (Exception $e) {

    var_dump($e);
}

К сожалению, он возвращает ошибку в сгенерированном файле Excel:

Предупреждение: ZipArchive :: close (): сбой при создании временного файла: такого файла или каталога нет в /Applications/XAMPP/xamppfiles/htdocs/bdoparticipantenweekend.nl/vendor/phpoffice/phpspreadsheet/src/PhpSpreadsheet Writer / Xlsx.php в строке 409

Я понимаю ошибку, я просто не знаю, как ее исправить. Я единственный, кто имеет эту ошибку в офисе, конечно .. Я единственный, кто использует PHP 7

Я провел некоторое исследование, по-видимому, PHP 7 как еще одно поведение относительно Zip :: close (): https://www.php.net/manual/en/ziparchive.close.php#119960

Кто-нибудь знает, как это исправить?

Примечание: PhpSpreadsheet обновляется до версии 1.8.2 (последней)

1 Ответ

0 голосов
/ 10 июля 2019

Ваш путь неверен или у вас нет разрешения на запись в путь.Измените путь назначения или разрешения.

...