Компрессионные фильтры
В то время, как Компрессионные
обвёртки обеспечивают способ создания gzip- и bz2-совместимых
файлов в локальной файловой системе, они не предоставляют общих средств
средств для компрессии в сетевых потоках, как не предоставляют и средств
для создания потока без компрессии с последующим превращением в
компрессируемый. Для этих целей к любым потоковым ресурсам в любое время
могут применяться компрессионные фильтры.
Замечание:
Компрессионные фильтры не генерируют заголовков и
окончаний, которые используют утилиты командной строки, такие как
gzip. Они просто компрессируют (сжимают) и
декомпрессируют (разжимают) порции данных в компрессируемом потоке
данных.
zlib.deflate (компрессия) и
zlib.inflate (декомпрессия) являются реализациями
компрессионных методов, описаных в
» RFC 1951.
Фильтр deflate принимает три аргумента, переданных в
виде ассоциативного массива.
level
определяет, какой уровень компрессии
использовать (1-9). Повышение этого значения приведёт к уменьшению
объёмов данных за счёт увеличения времени обработки. Существуют так же два
специальных уровня компрессии:
0 (для отключения компрессии) и -1 (внутреннее значение по умолчанию
библиотеки zlib -- на текущий момент равно 6).
window
- это логарифм размера окна диапазона сжатия,
где база логарифма составляет 2.
Высокие значения (вплоть до 15 -- 32768 байт) приводят к улучшению
компрессии за счёт роста необходимой памяти, в то время как низкие значения
(вплоть дл 9 -- 512 байт) приводят к ухудшению компрессии за счёт
уменьшения необходимой памяти.
Значением аргумента window
по умолчанию на текущий
момент является 15.
memory
определяет масштаб резервируемой памяти.
Допустимые значения находятся в диапазоне от 1 (минимальное резервирование)
до 9 (максимальное резервирование). Такое резервирование памяти влияет
только на скорость и не влияет на размер генерируемых данных..
Замечание:
Так как уровень компрессии является наиболее часто используемым
аргументом, вы можете передать только его в качестве обычного целого
числа (integer), вместо того чтобы передавать массив из одного элемента.
Компрессионные фильтры zlib.* доступны с версии PHP
5.1.0, если включена поддержка
zlib. Они так же доступны в качестве
обратного порта для версий 5.0.x путём установки
пакета » zlib_filter
из » PECL.
Эти фильтры не доступны в PHP 4.
Пример #1
zlib.deflate и
zlib.inflate
<?php
$params = array('level' => 6, 'window' => 15, 'memory' => 9);
$original_text = "This is a test.\nThis is only a test.\nThis is not an important string.\n";
echo "The original text is " . strlen($original_text) . " characters long.\n";
$fp = fopen('test.deflated', 'w');
stream_filter_append($fp, 'zlib.deflate', STREAM_FILTER_WRITE, $params);
fwrite($fp, $original_text);
fclose($fp);
echo "The compressed file is " . filesize('test.deflated') . " bytes long.\n";
echo "The original text was:\n";
/* Use readfile and zlib.inflate to decompress on the fly */
readfile('php://filter/zlib.inflate/resource=test.deflated');
/* Generates output:
The original text is 70 characters long.
The compressed file is 56 bytes long.
The original text was:
This is a test.
This is only a test.
This is not an important string.
*/
?>
Пример #2
Упрощённое использование zlib.deflate
<?php
$original_text = "This is a test.\nThis is only a test.\nThis is not an important string.\n";
echo "The original text is " . strlen($original_text) . " characters long.\n";
$fp = fopen('test.deflated', 'w');
/* Here "6" indicates compression level 6 */
stream_filter_append($fp, 'zlib.deflate', STREAM_FILTER_WRITE, 6);
fwrite($fp, $original_text);
fclose($fp);
echo "The compressed file is " . filesize('test.deflated') . " bytes long.\n";
/* Generates output:
The original text is 70 characters long.
The compressed file is 56 bytes long.
*/
?>
bzip2.compress и
bzip2.decompress
работают точно так же, как и фильтры zlib, онисанные выше.
Фильтр bzip2.compress принимает два аргумента в виде
элементов ассоциативного массива:
blocks
является целочисленным (integer) значением
в диапазоне от 1 до 9 и указывает на количество 100-килобайтовых блоков
памяти для резервирования в качестве рабочего пространства.
work
- это так же целочисленное (integer) значение
в диапазоне от 0 до 250, определяющее сколько усилий нужно потратить на
обычный метод компрессии перед переключением на медленный, но более
надёжный метод. Изменение этого параметра влияет только на скорость
компрессии. Ни размер сжатого результата, ни используемый объём памяти не
изменяются при помощи этой настройки. Значение 0 указывает библиотеке bzip
использовать собственное внутреннее значение по умолчанию.
Фильтр bzip2.decompress принимает всего один аргумент,
который может быть передан либо как обычное boolean-значение, либо как
элемент small
ассоциативного массива.
Когда small
установлен в TRUE, библиотека bzip
совершит декомпрессию с минимальным расходом памяти за счёт понижения
скорости.
Компрессионные фильтры bzip2.* доступны с версии PHP
5.1.0, если включена поддержка
bz2. Они так же доступны в качестве
обратного порта для версий 5.0.x путём установки
пакета » bz2_filter
из » PECL.
Эти фильтры не доступны в PHP 4.
Пример #3
bzip2.compress и
bzip2.decompress
<?php
$param = array('blocks' => 9, 'work' => 0);
echo "The original file is " . filesize('LICENSE') . " bytes long.\n";
$fp = fopen('LICENSE.compressed', 'w');
stream_filter_append($fp, 'bzip2.compress', STREAM_FILTER_WRITE, $param);
fwrite($fp, file_get_contents('LICENSE'));
fclose($fp);
echo "The compressed file is " . filesize('LICENSE.compressed') . " bytes long.\n";
/* Generates output:
The original text is 3288 characters long.
The compressed file is 1488 bytes long.
*/
?>