48 lines
1.3 KiB
ReStructuredText
Raw Normal View History

2024-07-10 18:28:19 +05:45
Adding Content-Length header
=============
2024-09-29 16:59:27 +05:45
Adding a ``Content-Length`` header for ``ZipStream`` can be achieved by
using the options ``SIMULATION_STRICT`` or ``SIMULATION_LAX`` in the
``operationMode`` parameter.
2024-07-10 18:28:19 +05:45
2024-09-29 16:59:27 +05:45
In the ``SIMULATION_STRICT`` mode, ``ZipStream`` will not allow to calculate the
size based on reading the whole file. ``SIMULATION_LAX`` will read the whole
file if neccessary.
2024-07-10 18:28:19 +05:45
2024-09-29 16:59:27 +05:45
``SIMULATION_STRICT`` is therefore useful to make sure that the size can be
calculated efficiently.
2024-07-10 18:28:19 +05:45
2024-09-29 16:59:27 +05:45
.. code-block:: php
use ZipStream\OperationMode;
use ZipStream\ZipStream;
$zip = new ZipStream(
operationMode: OperationMode::SIMULATE_STRICT, // or SIMULATE_LAX
defaultEnableZeroHeader: false,
sendHttpHeaders: true,
outputStream: $stream,
);
// Normally add files
$zip->addFile('sample.txt', 'Sample String Data');
// Use addFileFromCallback and exactSize if you want to defer opening of
// the file resource
$zip->addFileFromCallback(
'sample.txt',
exactSize: 18,
callback: function () {
return fopen('...');
2024-07-10 18:28:19 +05:45
}
2024-09-29 16:59:27 +05:45
);
2024-07-10 18:28:19 +05:45
2024-09-29 16:59:27 +05:45
// Read resulting file size
$size = $zip->finish();
// Tell it to the browser
header('Content-Length: '. $size);
// Execute the Simulation and stream the actual zip to the client
$zip->executeSimulation();
2024-07-10 18:28:19 +05:45