5

我正在使用zlib.NET库来尝试扩充由 zlib 压缩的文件(也许在 Linux 机器上)。这就是我正在做的事情:

zlib.ZInputStream zinput =
    new zlib.ZInputStream(File.Open(path, FileMode.Open, FileAccess.Read));

while (stopByte != (data = zinput.ReadByte()))
{
  // check data here
}

zinput.Close();

数据字节与压缩数据字节匹配,所以我一定做错了什么。

4

6 回答 6

7

除了即使面对异常也没有使用“使用”语句来关闭流,这对我来说看起来不错。数据确定是压缩的吗?你能在linux机器上用zlib解压吗?

查看源代码后,它非常可怕 - 例如,调用int Read(buffer, offset, length)最终将调用其内部int Read()方法length时间。鉴于这种不稳定的开始,我不确定我是否会特别信任代码,但我希望它至少能稍微工作!您是否尝试过使用SharpZipLib

于 2008-10-09T02:38:56.287 回答
7

看来我错误地假设所有虚拟方法都被覆盖了,但事实并非如此。我使用的是 zlib.ZInputStream.ReadByte(),它只是继承的 Stream.ReadByte(),它不会做任何膨胀。

我改用 zlib.ZInputStream.Read() ,它的工作原理应该是这样。

于 2008-10-09T16:02:18.367 回答
4

跳过 zlib 标头(前两个字节78 9C),然后使用DeflateStream内置的 .net 对我有用。

using(var input = File.OpenRead(...))
using(var output = File.Create(...))
{
    // if there are additional headers before the zlib header, you can skip them:
    // input.Seek(xxx, SeekOrigin.Current);

    if (input.ReadByte() != 0x78 || input.ReadByte() != 0x9C)//zlib header
        throw new Exception("Incorrect zlib header");

    using (var deflateStream = new DeflateStream(decryptedData, CompressionMode.Decompress, true))
    {
        deflateStream.CopyTo(output);
    }
}
于 2015-11-22T13:05:38.920 回答
2

下面的代码可以帮助你们。实例化对象并使用函数。

public class FileCompressionUtility
{
    public FileCompressionUtility()
    {
    }

    public static void CopyStream(System.IO.Stream input, System.IO.Stream output)
    {
        byte[] buffer = new byte[2000];
        int len;
        while ((len = input.Read(buffer, 0, 2000)) > 0)
        {
            output.Write(buffer, 0, len);
        }
        output.Flush();
    }

    public void compressFile(string inFile, string outFile)
    {
        System.IO.FileStream outFileStream = new System.IO.FileStream(outFile, System.IO.FileMode.Create);
        zlib.ZOutputStream outZStream = new zlib.ZOutputStream(outFileStream, zlib.zlibConst.Z_DEFAULT_COMPRESSION);
        System.IO.FileStream inFileStream = new System.IO.FileStream(inFile, System.IO.FileMode.Open);
        try
        {
            CopyStream(inFileStream, outZStream);
        }
        finally
        {
            outZStream.Close();
            outFileStream.Close();
            inFileStream.Close();
        }
    }

    public void uncompressFile(string inFile, string outFile)
    {
        int data = 0;
        int stopByte = -1;
        System.IO.FileStream outFileStream = new System.IO.FileStream(outFile, System.IO.FileMode.Create);
        zlib.ZInputStream inZStream = new zlib.ZInputStream(System.IO.File.Open(inFile, System.IO.FileMode.Open, System.IO.FileAccess.Read));
        while (stopByte != (data = inZStream.Read()))
        {
            byte _dataByte = (byte)data;
            outFileStream.WriteByte(_dataByte);
        }

        inZStream.Close();
        outFileStream.Close();
    }
}
于 2009-01-23T16:35:03.900 回答
2

我最近不幸将以前使用 php 的 zlib'd 文档提供给包括 IE7 在内的各种浏览器和平台。一旦我发现文档是 zlib'd 而不是 gzip'd(如当时所想的那样),我在 .NET Framework v4 中以下列方式使用了SharpZipLib(利用Stream.CopyTo):

public static byte[] DecompressZlib(Stream source)
{
    byte[] result = null;
    using (MemoryStream outStream = new MemoryStream())
    {
        using (InflaterInputStream inf = new InflaterInputStream(source))
        {
            inf.CopyTo(outStream);
        }
        result = outStream.ToArray();
    }
    return result;
}

我想我会把它放在这里,以防有人需要帮助来使用 SharpZipLib 的类。

于 2013-03-12T14:12:58.943 回答
0

更仔细地查看示例代码,它将数据从常规 Filestream 复制到 ZOutputStream。减压必须通过该层进行。

private void decompressFile(string inFile, string outFile)
{
    System.IO.FileStream outFileStream = new System.IO.FileStream(outFile, System.IO.FileMode.Create);
    zlib.ZOutputStream outZStream = new zlib.ZOutputStream(outFileStream);
    System.IO.FileStream inFileStream = new System.IO.FileStream(inFile, System.IO.FileMode.Open);          
    try
    {
        CopyStream(inFileStream, outZStream);
    }
    finally
    {
        outZStream.Close();
        outFileStream.Close();
        inFileStream.Close();
    }
}
于 2008-10-09T04:15:31.820 回答