using System.IO; using System.IO.Compression; using System.Data; using System.Data.sqlClient; using System.Runtime.Serialization.Formatters.Binary; //DataSet #region [ WebMethod(Description=" 直接返回DataSet对象 ")] public DataSet GetDataSet() { string sql = "select * from ds_test" ; sqlConnection sqlConn = new sqlConnection(@"server=WSH-S1112001\sql2005;uid=sa;pwd=R^c123;database=db_test" ); sqlConn.open(); sqlDataAdapter sqlDa = new sqlDataAdapter(sql,sqlConn); DataSet ds = new DataSet( "ds_test"); sqlDa.Fill(ds); sqlDa.dispose(); sqlConn.Close(); return ds; } [ WebMethod(Description = " 返回DataSet对象用 Binary序列化后的字节数组")] public byte [] GetDataSetBytes() { DataSet ds = GetDataSet(); BinaryFormatter ser = new BinaryFormatter(); MemoryStream ms = new MemoryStream(); ser.Serialize(ms,ds); byte[] buffer = ms.ToArray(); return buffer; } [ WebMethod(Description = " 返回DataSetSurrogate对象用 Binary序列化后的字节数组")] public byte [] GetDataSetSurrogateBytes() { DataSet ds = GetDataSet(); dss. DataSetSurrogate dss = new dss.DataSetSurrogate(ds); BinaryFormatter ser = new BinaryFormatter(); MemoryStream ms = new MemoryStream(); ser.Serialize(ms,dss); byte[] buffer = ms.ToArray(); return buffer; } [ WebMethod(Description = " 返回DataSetSurrogate对象用 Binary序列化并ZIP 压缩后的字节数组 ")] public byte [] GetDataSetSurrogateZipBytes() { DataSet ds = GetDataSet(); dss. DataSetSurrogate dss = new dss.DataSetSurrogate(ds); BinaryFormatter ser = new BinaryFormatter(); MemoryStream ms = new MemoryStream(); ser.Serialize(ms,dss); byte[] buffer = ms.ToArray(); byte[] zipbuffer = Compress(buffer); return zipbuffer; } public byte [] Compress(byte[] data) { MemoryStream ms = new MemoryStream(); Stream zipStream = null ; zipStream = new GZipStream (ms,CompressionMode.Compress,true); zipStream.Write(data,data.Length); zipStream.Close(); ms.Position = 0; byte[] compressed_data=new byte[ms.Length]; ms.Read(compressed_data,int.Parse(ms.Length.ToString())); return compressed_data; } #endregion
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。