官方帮助手册
http://www.zlib.net/manual.html
 
#include <stdlib.h>
#include <string.h>
#include <errno.h>
#include <stdio.h>
#include "zlib.h"
 
/* Compress data */
int zcompress(Bytef *data , uLong ndata ,
                       Bytef * zdata, uLong * nzdata)
{
        z_stream c_stream;
        int err = 0;
        if( data && ndata > 0)
       {
              c_stream.zalloc = ( alloc_func)0;
              c_stream.zfree = ( free_func)0;
              c_stream.opaque = ( voidpf)0;
               if( deflateInit(&c_stream, Z_DEFAULT_COMPRESSION ) != Z_OK ) return -1;
              c_stream.next_in = data;
              c_stream.avail_in = ndata;
              c_stream.next_out = zdata;
              c_stream.avail_out = * nzdata;
               while (c_stream.avail_in != 0 && c_stream.total_out < * nzdata)
              {
                      if(deflate(&c_stream, Z_NO_FLUSH) != Z_OK ) return -1;
              }
               if(c_stream.avail_in != 0) return c_stream.avail_in;
               for (;;) {
                      if((err = deflate(&c_stream, Z_FINISH)) == Z_STREAM_END) break;
                      if(err != Z_OK) return -1;
              }
               if(deflateEnd(&c_stream) != Z_OK) return -1;
              * nzdata = c_stream.total_out;
               return 0;
       }
        return -1;
}
/* Compress gzip data */
int gzcompress(Bytef *data , uLong ndata ,
                        Bytef * zdata, uLong * nzdata)
{
        z_stream c_stream;
        int err = 0;
        if( data && ndata > 0)
       {
              c_stream.zalloc = ( alloc_func)0;
              c_stream.zfree = ( free_func)0;
              c_stream.opaque = ( voidpf)0;
               if( deflateInit2(&c_stream, Z_DEFAULT_COMPRESSION , Z_DEFLATED ,
                     - MAX_WBITS, 8, Z_DEFAULT_STRATEGY) != Z_OK ) return -1;
              c_stream.next_in = data;
              c_stream.avail_in = ndata;
              c_stream.next_out = zdata;
              c_stream.avail_out = * nzdata;
               while (c_stream.avail_in != 0 && c_stream.total_out < * nzdata)
              {
                      if(deflate(&c_stream, Z_NO_FLUSH) != Z_OK ) return -1;
              }
               if(c_stream.avail_in != 0) return c_stream.avail_in;
               for (;;) {
                      if((err = deflate(&c_stream, Z_FINISH)) == Z_STREAM_END) break;
                      if(err != Z_OK) return -1;
              }
               if(deflateEnd(&c_stream) != Z_OK) return -1;
              * nzdata = c_stream.total_out;
               return 0;
       }
        return -1;
}
/* Uncompress data */
int zdecompress(Byte *zdata , uLong nzdata ,
                            Byte * data, uLong * ndata)
{
        int err = 0;
        z_stream d_stream; /* decompression stream */
       d_stream.zalloc = ( alloc_func)0;
       d_stream.zfree = ( free_func)0;
       d_stream.opaque = ( voidpf)0;
       d_stream.next_in = zdata;
       d_stream.avail_in = 0;
       d_stream.next_out = data;
        if( inflateInit(&d_stream) != Z_OK ) return -1;
        while (d_stream.total_out < * ndata && d_stream.total_in < nzdata) {
              d_stream.avail_in = d_stream.avail_out = 1; /* force small buffers */
               if((err = inflate(&d_stream, Z_NO_FLUSH)) == Z_STREAM_END ) break ;
               if(err != Z_OK) return -1;
       }
        if(inflateEnd(&d_stream) != Z_OK) return -1;
       * ndata = d_stream.total_out;
        return 0;
}
/* HTTP gzip decompress */
int httpgzdecompress(Byte *zdata , uLong nzdata ,
                                   Byte * data, uLong * ndata)
{
        int err = 0;
        z_stream d_stream = {0}; /* decompression stream */
        static char dummy_head[2] =
       {
              0x8 + 0x7 * 0x10,
              (((0x8 + 0x7 * 0x10) * 0x100 + 30) / 31 * 31) & 0xFF,
       };
       d_stream.zalloc = ( alloc_func)0;
       d_stream.zfree = ( free_func)0;
       d_stream.opaque = ( voidpf)0;
       d_stream.next_in = zdata;
       d_stream.avail_in = 0;
       d_stream.next_out = data;
        if( inflateInit2(&d_stream, 47) != Z_OK ) return -1;
        while (d_stream.total_out < * ndata && d_stream.total_in < nzdata) {
              d_stream.avail_in = d_stream.avail_out = 1; /* force small buffers */
               if((err = inflate(&d_stream, Z_NO_FLUSH)) == Z_STREAM_END ) break ;
               if(err != Z_OK )
              {
                      if(err == Z_DATA_ERROR)
                     {
                           d_stream.next_in = ( Bytef*) dummy_head;
                           d_stream.avail_in = sizeof(dummy_head);
                            if((err = inflate(&d_stream, Z_NO_FLUSH)) != Z_OK )
                           {
                                   return -1;
                           }
                     }
                      else return -1;
              }
       }
        if(inflateEnd(&d_stream) != Z_OK) return -1;
       * ndata = d_stream.total_out;
        return 0;
}
/* Uncompress gzip data */
int gzdecompress(Byte *zdata , uLong nzdata ,
                            Byte * data, uLong * ndata)
{
       
        int err = 0;
        z_stream d_stream = {0}; /* decompression stream */
        static char dummy_head[2] =
       {
              0x8 + 0x7 * 0x10,
              (((0x8 + 0x7 * 0x10) * 0x100 + 30) / 31 * 31) & 0xFF,
       };
 
        int v = 20;
       * ndata = 20;
        for (;v<65330; v++)
       {
               zdata[v] = '\0';
       }
 
 
       d_stream.zalloc = ( alloc_func)0;
       d_stream.zfree = ( free_func)0;
       d_stream.opaque = ( voidpf)0;
       d_stream.next_in = zdata;
       d_stream.avail_in = 0;
       d_stream.next_out = data;
        if( inflateInit2(&d_stream, -MAX_WBITS ) != Z_OK ) return -1;
        //if(inflateInit2(&d_stream, 47) != Z_OK) return -1;
        while (d_stream.total_out < * ndata && d_stream.total_in < nzdata) {
              d_stream.avail_in = d_stream.avail_out = 1; /* force small buffers */
               if((err = inflate(&d_stream, Z_NO_FLUSH)) == Z_STREAM_END ) break ;
               if(err != Z_OK )
              {
                      if(err == Z_DATA_ERROR)
                     {
                           d_stream.next_in = ( Bytef*) dummy_head;
                           d_stream.avail_in = sizeof(dummy_head);
                            if((err = inflate(&d_stream, Z_NO_FLUSH)) != Z_OK )
                           {
                                   return -1;
                           }
                     }
                      else return -1;
              }
       }
        if(inflateEnd(&d_stream) != Z_OK) return -1;
       * ndata = d_stream.total_out;
        return 0;
}
 
int main()
{
 
        char *data = "hello word. this test message for this programe.for our work!hello word. this test message for this programe.for our work!hello word. this test message for this programe.for our work!";
        uLong ndata = strlen(data);
        Bytef zdata[ BUF_SIZE];
        uLong nzdata = BUF_SIZE;
        Bytef odata[ BUF_SIZE];
        uLong nodata = BUF_SIZE;
       memset(zdata, 0, BUF_SIZE);
 
        //if(zcompress((Bytef *)data, ndata, zdata, &nzdata) == 0)
        if(gzcompress(( Bytef *)data, ndata, zdata, &nzdata) == 0)
       {
              fprintf( stdout, "nzdata:%d %s\n", nzdata, zdata);
              memset(odata, 0, BUF_SIZE);
               //if(zdecompress(zdata, ndata, odata, &nodata) == 0)
               if(gzdecompress(zdata, ndata, odata, &nodata) == 0)
               //if(httpgzdecompress(zdata, ndata, odata, &nodata) == 0)
              {
                     fprintf( stdout, "%d %s\n", nodata, odata);
              }
       }
}
  

zlib stream的更多相关文章

  1. composer "Failed to decode zlib stream"

    dockerFile 中安装composer.... RUN curl -s -f -L -o /tmp/installer.php https://raw.githubusercontent.com ...

  2. centos7 php7 安装composer时Failed to decode zlib stream解决办法

    1 下载安装脚本 php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');" 2 运行安装脚 ...

  3. 安装composer Failed to decode zlib stream 问题解决方法

    https://getcomposer.org/download/ 页面下载最新版本 composer.phar 放到php.exe 页面下.创建一个.bat文件,存入下面内容 @ECHO OFF p ...

  4. composer Failed to decode zlib stream 无法解码zlib流

    Win7 中安装 Composer (PHP) 国内有些网络不能访问美国的Composer官网,可访问 Composer 中文网 学习. 目标 可以在任何目录下的项目中执行 PHP composer. ...

  5. win7安装composer Failed to decode zlib stream

    今天学习php的时候想安装一下composer,刚开始采用的是exe文件的安装方式,可是安装了好几次都没有安装成功,如下图: 可能还有其他的一些错误,所以这里我就换了一个方式安装,就是自己手动来安装c ...

  6. Win7下安装composer, 并使用其安装smarty

    安装composer需要开启PHP openssl扩展. 1) 先查看PHP是否开启了openssl扩展 键盘win+r 输出cmd, 可以看到Dos窗口, 然后执行php -m (需要添加PHP环境 ...

  7. composer安装。

    我们这里实在Windows下进行的安装.1.下载Composer安装包.网址:https://getcomposer.org/download/下载Composer-Setup.exe 安装文件.2. ...

  8. table2excel使用

    原table2excel代码 /* * 采用jquery模板插件——jQuery Boilerplate * * Made by QuJun * 2017/01/10 */ //table2excel ...

  9. 如何查看PHP的配置信息

    1.问题描述 如何利用PHP函数查看PHP的配置信息 2.问题函数 <?php echo phpinfo(); ?> 3.输出结果 phpinfo() PHP Version => ...

随机推荐

  1. os--留

    os.path.abspath(path) #返回绝对路径    绝对路径和文件路径的区别,绝对路径是当前在操作文本的路径,文件路径是当前文本的文件的路径 os.path.basename(path) ...

  2. OZ customize windows iamge

    1.之前通过修改auto文件和windows.py文件可实现自动安装OS,但是disk bus只能以IDE模式启动,进入系统自动下载运行bat文件,安装cloudbase-init和qga,及清理日志 ...

  3. 2 28TOP100

    import json import requests from requests.exceptions import RequestException import re import time d ...

  4. 微信公众号开发java框架:wx4j(入门篇)

    导航 入门 http://www.cnblogs.com/2333/p/6617819.html WxServlet介绍 MaterialUtils 素材工具类使用说明 http://www.cnbl ...

  5. 用Margin还是用Padding?

    用margin还是用padding这个问题是每个学习CSS进阶时的必经之路. CSS边距属性定义元素周围的空间.通过使用单独的属性,可以对上.右.下.左的外边距进行设置.也可以使用简写的外边距属性同时 ...

  6. Angular & RxJS & Typesc­ript

    Angular & RxJS & Typesc­ript https://www.wmnetwork.cc/d/?mid=75627 杭州经开区国际创博中心 https://www.w ...

  7. Tomcat源码浅析

    最近在学习tomcat源码,算是把tomcat的整个流程梳理通了. 从上图来看,tomcat把模块化使用到了极致,配合组件生命周期的管理,让代码看起来结构清晰,而且很容易进行业务扩展. 1.上图的接口 ...

  8. 内存检测工具valgrind

    valgrind --tool=memcheck --leak-check=full --error-limit=no  --trace-children=yes  ./server valgrind ...

  9. 【转】VS常用快捷键

    每次在网上搜关于VS有哪些常用快捷键的时候,出来的永远是一串长的不能再长的列表,完全没体现出“常用”二字,每次看完前面几个就看不下去了,相信大家都 有这种感觉.其实我们平时用的真的只有很少的一部分,借 ...

  10. H3C交换机端口链路聚合

    H3C交换机端口链路聚合 以太网链路聚合 -- 以太网链路聚合配置命令 -- lacp system-prioritylacp system-priority命令用来配置系统的LACP优先级.undo ...