Content encoding deflate php
В то время, как Компрессионные обёртки обеспечивают способ создания gzip- и bz2-совместимых файлов в локальной файловой системе, они не предоставляют общих средств для компрессии в сетевых потоках, как и не предоставляют средств для создания потока без компрессии с последующим превращением в компрессируемый. Для этих целей к любым потоковым ресурсам в любое время могут применяться компрессионные фильтры.
Замечание: Компрессионные фильтры не генерируют заголовков и окончаний, которые используют утилиты командной строки, такие как gzip . Они просто компрессируют (сжимают) и декомпрессируют (разжимают) порции данных в компрессируемом потоке данных.
zlib.deflate и zlib.inflate
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.* доступны, если включена поддержка zlib.
Пример #1 zlib.deflate и zlib.inflate
$params = array( ‘level’ => 6 , ‘window’ => 15 , ‘memory’ => 9 );
?php
$original_text = «This is a test.\nThis is only a test.\nThis is not an important string.\n» ;
echo «Оригинальный текст длиной » . strlen ( $original_text ) . » символов.\n» ;
$fp = fopen ( ‘test.deflated’ , ‘w’ );
stream_filter_append ( $fp , ‘zlib.deflate’ , STREAM_FILTER_WRITE , $params );
fwrite ( $fp , $original_text );
fclose ( $fp );
echo «Сжатый файл размером » . filesize ( ‘test.deflated’ ) . » байт.\n» ;
echo «Оригинальный текст:\n» ;
/* Использование readfile и zlib.inflate для декомпресии на лету */
readfile ( ‘php://filter/zlib.inflate/resource=test.deflated’ );
Оригинальный текст длиной 70 символов.
Сжатый файл размером 56 байт.
Оригинальный текст:
This is a test.
This is only a test.
This is not an important string.
Пример #2 Упрощённое использование zlib.deflate
$original_text = «This is a test.\nThis is only a test.\nThis is not an important string.\n» ;
echo «Оригинальный текст длиной » . strlen ( $original_text ) . » символов.\n» ;
?php
$fp = fopen ( ‘test.deflated’ , ‘w’ );
/* Здесь «6» указывает уровень компрессии 6 */
stream_filter_append ( $fp , ‘zlib.deflate’ , STREAM_FILTER_WRITE , 6 );
fwrite ( $fp , $original_text );
fclose ( $fp );
echo «Сжатый файл размером » . filesize ( ‘test.deflated’ ) . » байт.\n» ;
Оригинальный текст длиной 70 символов.
Сжатый файл размером 56 байт.
bzip2.compress и bzip2.decompress
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.* доступны, если включена поддержка bz2.
Пример #3 bzip2.compress и bzip2.decompress
echo «Оригинальный файл размером » . filesize ( ‘LICENSE’ ) . » байт.\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 «Сжатый файл размером » . filesize ( ‘LICENSE.compressed’ ) . » байт.\n» ;
Оригинальный файл размером 3288 байт.
Сжатый файл размером 1488 байт.
gzdeflate
This function compresses the given string using the DEFLATE data format.
For details on the DEFLATE compression algorithm see the document «» DEFLATE Compressed Data Format Specification version 1.3» (RFC 1951).
Parameters
The level of compression. Can be given as 0 for no compression up to 9 for maximum compression. If not given, the default compression level will be the default compression level of the zlib library.
One of ZLIB_ENCODING_* constants.
Return Values
The deflated string or false if an error occurred.
Examples
Example #1 gzdeflate() example
See Also
- gzinflate() — Inflate a deflated string
- gzcompress() — Compress a string
- gzuncompress() — Uncompress a compressed string
- gzencode() — Create a gzip compressed string
User Contributed Notes 9 notes
Take care that that «PHP deflate» != «HTTP deflate».
The deflate encoding used in HTTP is actually zlib encoded.
This is what PHP functions return:
gzencode() == gzip
gzcompress() == zlib (aka. HTTP deflate)
gzdeflate() == *raw* deflate encoding
gzcompress produces longer data because it embeds information about the encoding onto the string. If you are compressing data that will only ever be handled on one machine, then you don’t need to worry about which of these functions you use. However, if you are passing data compressed with these functions to a different machine you should use gzcompress.
running 50000 repetitions on various content, i found that gzdeflate() and gzcompress() both performed equally fast regardless content and compression level, but gzinflate() was always about twice as fast as gzuncompress().
After some searching and experimentation I found that the output from this function cannot be ‘inflated’ with the objective c ‘zlibInflate’ wrapper for ‘zlib’ that is available at http://cocoadev.com/wiki/NSDataCategory but the output from gzcompress() can be. Thank you «anonymous at php dot net» and «tomas at slax dot org» for the clues. I hope this saves someone else the searching.
The HTTP deflate is quite complicated.
The RFC7230, Sec 4.2.2 (https://tools.ietf.org/html/rfc7230#section-4.2.2) says:
«The «deflate» coding is a «zlib» data format [RFC1950] containing a «deflate» compressed data stream [RFC1951] that uses a combination of the Lempel-Ziv (LZ77) compression algorithm and Huffman coding.»
and, also:
«Note: Some non-conformant implementations send the «deflate» compressed data without the zlib wrapper.»
Since this function implements the RFC1951, the compliant encoding of a $payload should be:
gzcompress() is the same like gzdefflate(), it produces identical data and its speed is the same as well. The only difference is that gzcompress produces 6 bytes bigger result (2 extra bytes at the beginning and 4 extra bytes at the end).
if you have compressed data which is greater than 2 MB (system dependent), you will receive a buffer error by calling the function gzinflate().
be sure to to compress your data by a lower compression level, like 1.
i.e.: gzdeflate($sData, 1);
The «One of ZLIB_ENCODING_* constants.» seems to be available only from PHP 5.4.
So I guess that is you are PHP 5.3 you don’t use the $encoding parameter.
gzinflate
The original uncompressed data or false on error.
The function will return an error if the uncompressed data is more than 32768 times the length of the compressed input data or, unless max_length is 0 , more than the optional parameter max_length .
Examples
Example #1 gzinflate() example
$compressed = gzdeflate ( ‘Compress me’ , 9 );
$uncompressed = gzinflate ( $compressed );
echo $uncompressed ;
?>?php
See Also
- gzdeflate() — Deflate a string
- gzcompress() — Compress a string
- gzuncompress() — Uncompress a compressed string
- gzencode() — Create a gzip compressed string
User Contributed Notes 10 notes
To decode / uncompress the received HTTP POST data in PHP code, request data coming from Java / Android application via HTTP POST GZIP / DEFLATE compressed format
1) Data sent from Java Android app to PHP using DeflaterOutputStream java class and received in PHP as shown below
echo gzinflate( substr($HTTP_RAW_POST_DATA,2,-4) ) . PHP_EOL . PHP_EOL;
2) Data sent from Java Android app to PHP using GZIPOutputStream java class and received in PHP code as shown below
echo gzinflate( substr($HTTP_RAW_POST_DATA,10,-8) ) . PHP_EOL . PHP_EOL;
From Java Android side (API level 10+), data being sent in DEFLATE compressed format
String body = «Lorem ipsum shizzle ma nizle»;
URL url = new URL(«http://www.url.com/postthisdata.php»);
URLConnection conn = url.openConnection();
conn.setDoOutput(true);
conn.setRequestProperty(«Content-encoding», «deflate»);
conn.setRequestProperty(«Content-type», «application/octet-stream»);
DeflaterOutputStream dos = new DeflaterOutputStream(
conn.getOutputStream());
dos.write(body.getBytes());
dos.flush();
dos.close();
BufferedReader in = new BufferedReader(new InputStreamReader(
conn.getInputStream()));
String decodedString = «»;
while ((decodedString = in.readLine()) != null) Log.e(«dump»,decodedString);
>
in.close();
On PHP side (v 5.3.1), code for decompressing this DEFLATE data will be
echo substr($HTTP_RAW_POST_DATA,2,-4);
From Java Android side (API level 10+), data being sent in GZIP compressed format
String body1 = «Lorem ipsum shizzle ma nizle»;
URL url1 = new URL(«http://www.url.com/postthisdata.php»);
URLConnection conn1 = url1.openConnection();
conn1.setDoOutput(true);
conn1.setRequestProperty(«Content-encoding», «gzip»);
conn1.setRequestProperty(«Content-type», «application/octet-stream»);
GZIPOutputStream dos1 = new GZIPOutputStream(conn1.getOutputStream());
dos1.write(body1.getBytes());
dos1.flush();
dos1.close();
BufferedReader in1 = new BufferedReader(new InputStreamReader(
conn1.getInputStream()));
String decodedString1 = «»;
while ((decodedString1 = in1.readLine()) != null) Log.e(«dump»,decodedString1);
>
in1.close();
On PHP side (v 5.3.1), code for decompressing this GZIP data will be
echo substr($HTTP_RAW_POST_DATA,10,-8);
Useful PHP code for printing out compressed data using all available formats.
$data = «Lorem ipsum shizzle ma nizle»;
echo «\n\n\n»;
for($i=-1;$i <=9;$i++)
echo chunk_split(strtoupper(bin2hex(gzcompress($data,$i))),2,» «) . PHP_EOL . PHP_EOL;
echo «\n\n\n»;
for($i=-1;$i <=9;$i++)
echo chunk_split(strtoupper(bin2hex(gzdeflate($data,$i))),2,» «) . PHP_EOL . PHP_EOL;
echo «\n\n\n»;
for($i=-1;$i <=9;$i++)
echo chunk_split(strtoupper(bin2hex(gzencode($data,$i,FORCE_GZIP))),2,» «) . PHP_EOL . PHP_EOL;
echo «\n\n\n»;
for($i=-1;$i <=9;$i++)
echo chunk_split(strtoupper(bin2hex(gzencode($data,$i,FORCE_DEFLATE))),2,» «) . PHP_EOL . PHP_EOL;
echo «\n\n\n»;
Hope this helps. Please ThumbsUp if this saved you a lot of effort and time.