我正在使用C#的System.IO类(框架4.0)来压缩从文件系统中获取的图像,并使用FileDialog插入到SQL Server数据库中作为varbinary(max)数据类型。 我遇到的问题是,当我从数据库中提取数据并尝试解压缩时,我会得到一个错误,附加信息为-确保您传递了gzip流。
获取文件的代码:
压缩方法:
解压缩方法:
获取文件的代码:
OpenFileDialog dlgOpen = new OpenFileDialog();
if (dlgOpen.ShowDialog() == DialogResult.OK)
{
FileStream fs = File.OpenRead(dlgOpen.FileName);
byte[] picbyte1 = new byte[fs.Length];
byte[] picbyte = Compress(picbyte1);
fs.Read(picbyte, 0, System.Convert.ToInt32(picbyte.Length));
String ImageName = dlgOpen.FileName;
//String bs64OfBytes = Convert.ToBase64String(picbyte);
fs.Close();
//additional code inserts into database
....
}
压缩方法:
private static byte[] Compress(byte[] data)
{
var output = new MemoryStream();
using (var gzip = new GZipStream(output, CompressionMode.Compress, true))
{
gzip.Write(data, 0, data.Length);
gzip.Close();
}
return output.ToArray();
}
解压缩方法:
private static byte[] Decompress(byte[] data)
{
var output = new MemoryStream();
var input = new MemoryStream();
input.Write(data, 0, data.Length);
input.Position = 0;
using (var gzip = new GZipStream(input, CompressionMode.Decompress, true))
{
var buff = new byte[64];//also used 32
var read = gzip.Read(buff, 0, buff.Length);//error occurs here
while (read > 0)
{
output.Write(buff, 0, read);
read = gzip.Read(buff, 0, buff.Length);
}
gzip.Close();
}
return output.ToArray();
}
Compress()
和Decompress()
操作,那么会出现什么情况?换句话说,如果直接将 Compress 的输出用作 Decompress 的输入,是否有效?通过这种方式,您可以确定代码或to/from database
代码的错误。请注意,不要更改原文意思。 - Sjips