webservice中将dataset 压缩
http://blog.csdn.net/bodaowang/article/details/6889446
在webservice中将dataset序列化是我们经常遇到的问题,但是遇到很大的dataset,则网络传输就必须考虑的问题,将dataset处理压缩后传输是我们不错的选择,下面提供这种方法:
第一步:引入命名空间下载DataSetSurrogate组件
using System.IO.Compression;
using System.Runtime.Serialization.Formatters.Binary;
将下载好的DataSetSurrogate放入bin路径下
第二步:压缩序列化
///序列化转化为二进制数组的DataSet
public byte[] GetDataSetSurrogateZipBYtes(DataSet DS)
{
DataSetSurrogate dss = new DataSetSurrogate(DS);
///二进制方式方式序列化
BinaryFormatter ser = new BinaryFormatter();
MemoryStream ms = new MemoryStream();
ser.Serialize(ms, dss);
byte[] buffer = ms.ToArray();
///调用压缩方法
byte[] Zipbuffer = Compress(buffer);
return Zipbuffer;
}
///压缩二进制文件
private byte[] Compress(byte[] data)
{
MemoryStream ms = new MemoryStream();
Stream zipStream = null;
zipStream = new GZipStream(ms, CompressionMode.Compress, true);
///从指定的字节数组中将压缩的字节写入基础流
zipStream.Write(data, 0, data.Length);
zipStream.Close();
ms.Position = 0;
byte[] Compressed_Data = new byte[ms.Length];
ms.Read(Compressed_Data, 0, int.Parse(ms.Length.ToString()));
return Compressed_Data;
}
第三部:解压反序列化
///将压缩后的二进制数组解压
public static byte[] Decompress(byte[] data)
{ ///data参数为压缩后的二进制数组
try
{
MemoryStream ms = new MemoryStream(data);
Stream zipStream = null;
zipStream = new GZipStream(ms, CompressionMode.Decompress);
byte[] dc_data = null;
dc_data = EtractBytesFormStream(zipStream, data.Length);
return dc_data;
///返回解压后的二进制数组
}
catch
{
return null;
}
}
/// 将二进制文件反序列化后转化为DataSet
public DataSet GetDatasetFromByte(byte[] ZipByte)
{
byte[] buffer = UnZipClass.Decompress(ZipByte);
BinaryFormatter ser = new BinaryFormatter();
DataSetSurrogate dss;
dss = (DataSetSurrogate)ser.Deserialize(new MemoryStream(buffer));
DataSet DS = dss.ConvertToDataSet();
return DS;
}
常用WebServices返回数据的4种方法比较
以前经常在群里听到朋友们说WebServices的性能特别的慢,说的如何如何。说实话,WebServices的确比调用本地数据要慢一些,可是究竟有多慢,真的如朋友们说的那么难以忍受吗?我个人感觉,多半原因在处理的方式上。让我们亲自编写测试代码,来证明这一切吧。文章由于是我一段时间的总结篇,因此难免参杂个人主观因素,说的不对的地方,还请多多批评。以下我们主要从调用WebServices的方法的特点、应用场景、测试结果三个方面来进行下说明分析。
-
直接返回DataSet对象
特点:直接返回DataSet对象。
应用场景:1.内网。2.外网且数据量在kb级别时。
2.返回DataSet对象用Binary序列化后的字节数组
特点:字节数组流的处理模式。
应用场景:较大数据交换。
3.返回DataSetSurrogate对象用Binary 序列化后的字节数组
特点:使用微软提供的开源组件进行序列化,依然是字节流的处理模式。详情请参考:http://support.microsoft.com/kb/829740/zh-cn
应用场景: 较大数据交换。
4.返回DataSetSurrogate对象用Binary 序列化并Zip压缩后的字节数组
特点:使用微软提供的开源组件对字节流数组进行压缩后传递,依然是字节流的处理模式。详情请参考:http://support.microsoft.com/kb/829740/zh-cn
应用场景:外网环境需要进行大数据量网络数据传递时,建议采用此种方法。也是笔者强烈向大家推荐使用的一种方法。
WebServices的代码如下:
WebServices
客户端调用WebServices的代码如下:
客户端调用WebServices
测试的结果按照先后顺序如下图所示:
关于测试结果的特殊说明:由于测试环境是在本地,数据量也不是很大,测试的结果离实际情况还不是很接近,如果大家有条件的话,可以测试一下,同时希望把测试的结果提供给大家参考。
最后,为了方便大家,这里还提供了源码下载,下载地址如下:
/Files/wlb/WebServiceSummary.rar
关于源代码的特殊说明:笔者这里的开发环境为VS2008中文版sp1+SQLServer2008sp1。数据库为Northwind数据库。
http://www.cnblogs.com/wlb/archive/2009/04/13/1434419.html
其他:
http://blog.csdn.net/qiujialongjjj/article/details/20033943