3

我一直在研究解析第 3 方 fms 日志的函数。日志在 Gzip 中,因此我使用了适用于我们使用的任何其他 Gzip 文件的解压缩功能。

解压这些文件时,我只得到压缩文件的第一行,也不例外,它只是没有找到其余的字节,就好像第一行有一个 EOF。我尝试使用 Ionic.Zlib 而不是 System.IO.Compression 但结果是一样的。这些文件似乎没有以任何方式损坏,使用 Winrar 解压缩它们。

如果有人知道如何解决这个问题,我将不胜感激。谢谢

您可以在此处下载示例文件:http: //www.adjustyourset.tv/fms_6F9E_20120621_0001.log.gz

这是我的解压功能:

    public static bool DecompressGZip(String fileRoot, String destRoot)
    {
        try
        {
            using (FileStream fileStram = new FileStream(fileRoot, FileMode.Open, FileAccess.Read))
            {
                using (FileStream fOutStream = new FileStream(destRoot, FileMode.Create, FileAccess.Write))
                {
                    using (GZipStream zipStream = new GZipStream(fileStram, CompressionMode.Decompress, true))
                    {
                        byte[] buffer = new byte[4096];
                        int numRead;

                        while ((numRead = zipStream.Read(buffer, 0, buffer.Length)) != 0)
                        {
                            fOutStream.Write(buffer, 0, numRead);
                        }
                        return true;
                    }
                }

            }
        }
        catch (Exception ex)
        {
            LogUtils.SaveToLog(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"), "Eror decompressing " + fileRoot + " : " + ex.Message, Constants.systemLog, 209715200, 6);
            return false;
        }
    }
4

1 回答 1

4

我已经在最后 45 分钟内解决了这个问题,但我无法解释为什么它不起作用。不知何故,DeflateStream 类没有正确解码您的数据。我编写了自己的 GZip 解析器(如果有人想检查它,我可以分享代码),它读取所有标题并检查它们的有效性(以确保那里没有有趣的东西),然后使用 DeflateStream 膨胀实际数据,但你的文件仍然只是让我第一行。

如果我使用 GZipStream 使用您的日志文件重新压缩(在首先使用 winrar 解压缩它之后),那么我自己的解析器和您自己的示例都会再次解压缩它。

网上似乎有一些关于微软实施 Deflate (http://www.virtualdub.org/blog/pivot/entry.php?id=335) 的批评,所以您可能发现了其中一个怪癖。

但是,解决您的问题的一个简单方法是切换到 SharZipLib (http://www.icsharpcode.net/opensource/sharpziplib/),我试过了,它可以很好地解压您的文件。

    public static void DecompressGZip(String fileRoot, String destRoot)
    {
        using (FileStream fileStram = new FileStream(fileRoot, FileMode.Open, FileAccess.Read))
        using (GZipInputStream zipStream = new GZipInputStream(fileStram))
        using (StreamReader sr = new StreamReader(zipStream))
        {
            string data = sr.ReadToEnd();
            File.WriteAllText(destRoot, data);
        }
    }
于 2012-06-26T11:13:09.000 回答