Webservice之Dataset传输[服务端]

4 篇文章 0 订阅
3 篇文章 0 订阅
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, 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;
        }
        #endregion

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值