利用.Net Framework2.0 zip压缩、解压 string 数据

it2022-05-09  19

利用System.IO.Compression 压缩,解压文件网上能搜索到很多文档了, 但对字符串直接压缩还是很少, 这种压缩还是在webservice返回大量数据时还是用用途的

看code吧:

using System.Text;

using System.IO.Compression;

public  static string CompressString(string str)       {           byte[] buffer = Encoding.Unicode.GetBytes(str);           MemoryStream ms = new MemoryStream();

          GZipStream zip = new GZipStream(ms, CompressionMode.Compress, true);           zip.Write(buffer, 0, buffer.Length);           zip.Close();           ms.Position = 0;           byte[] zipBuffer = new byte[ms.Length];           ms.Read(zipBuffer, 0, zipBuffer.Length);           ms.Close();           string zipstr =Convert.ToBase64String(zipBuffer);           return zipstr;       }

      public static string DeCompressString(string str)       {           byte[] buffer = Convert.FromBase64String(str);           MemoryStream ms = new MemoryStream();           ms.Write(buffer, 0, buffer.Length);           ms.Position = 0;           GZipStream zip = new GZipStream(ms, CompressionMode.Decompress, true);            byte[] zipBuffer = new byte[1024];            MemoryStream ms2 = new MemoryStream();            while (true)            {                int bytesRead = zip.Read(zipBuffer, 0, zipBuffer.Length);                if (bytesRead == 0)                {                    break;                }                ms2.Write(zipBuffer, 0, bytesRead);             }           zip.Close();

          string zipstr = Encoding.Unicode.GetString(ms2.ToArray(), 0, (int)ms2.Length);           return zipstr;       }

特别提示, 如果压缩方法直接返回byte[], 会节省一些空间, 而且byte[]可以直接存储到sql server binary数据类型里, 但考虑到webservcie传输, 我又把他转成string, 用Base64转成string会多花销一些空间, 但相比为压缩的string, 已经小了很多了。 如果用别的编码(比如utf8, unioncode) 会产生一些问题, 我想是因为一些特殊字符处理的问题吧,网上搜索base64编码是解决字符是7位的带符号位, 可能是这个问题

转载于:https://www.cnblogs.com/skyfei/archive/2008/08/07/1263159.html


最新回复(0)