浅谈WebService返回数据效率对比

简介: 本文转载:http://www.cnblogs.com/waynechan/archive/2012/06/25/2560685.html一、什么是WebService:        简单通俗来说,就是企业之间、网站之间通过Internet来访问并使用在线服务,一些数据,由于安全性问题,不能提供数据库给其他单位使用,这时候可以使   用WebService服务提供。

本文转载:http://www.cnblogs.com/waynechan/archive/2012/06/25/2560685.html

一、什么是WebService:

       简单通俗来说,就是企业之间、网站之间通过Internet来访问并使用在线服务,一些数据,由于安全性问题,不能提供数据库给其他单位使用,这时候可以使   用WebService服务提供。

二、创建WebService

创建WebService之后,我们就可以在文件里写返回数据的方法了。


三、返回数据的四种形式

笔者水平有限,只列出这四种数据的返回形式:

  (1)直接返回DataSet对象
   (2)返回DataSet对象用Binary序列化后的字节数组
   (3)返回DataSetSurrogate对象用Binary序列化后的 字节数组
   (4)返回DataSetSurrogate对象用Binary序列化并Zip 压缩后的字节数组


理论上来说,网络传输字节与传输时间,应该是递减的,其中,(3)(4)种方法需要引用微软提供的开源组件  下载地址:http://support.microsoft.com/kb/829740/zh-cn


下面展示这四种返回数据的代码,其中(1)是其三种方法的根本,都要得到一个DataSet作为根本,然后来做各种转换压缩的操作:

 

[WebMethod(Description =  " 直接返回DataSet对象 ")]  
      public DataSet GetDataSet()  
     {  
          string connStr = System.Configuration.ConfigurationManager.ConnectionStrings[ " conn "].ToString();  
         SqlConnection conn =  new SqlConnection(connStr);  
          string sql =  " select * from china_city ";  
         conn.Open();  
         SqlDataAdapter sda =  new SqlDataAdapter(sql, conn);  
         DataSet ds =  new DataSet( " China ");  
         sda.Fill(ds);  
         conn.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();  
         DataSetSurrogate dss =  new 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();  
         DataSetSurrogate dss =  new DataSetSurrogate(ds);  
         BinaryFormatter ser =  new BinaryFormatter();   // 序列化对象  
         MemoryStream ms =  new MemoryStream();   // 内存流  
         ser.Serialize(ms, dss);  
          byte[] buffer = ms.ToArray();     // 字节流  
          byte[] bufferZip = ComPress(buffer);  
          return buffer;  
     }  
      // 压缩方法  
      public  byte[] ComPress( byte[] data)  
     {  
          try  
         {  
             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,  0int.Parse(ms.Length.ToString()));  
              return compressed_data;  
         }  
          catch  
         {  
              return  null;  
         }  
     }

 

我们可以在浏览器中查看下WebService的效果,如图,在这个页面中,有提供四个方法,这四个方法就是上述我们写的四个返回数据的方法了,点击方法即可返回相应的数据,这样,我们数据提供方的代码就可以写好了,接下来,我们写调用数据的方法!



四、调用数据

客户端WebService程序

 

 

复制代码
private void button1_Click( object sender, EventArgs e) 
    { 
        com.dzbsoft.www.Service1 ds = new com.dzbsoft.www.Service1();  // new出WebService对象 
        DateTime dtBegin = DateTime.Now; 
        DataSet dataSet = ds.GetNorthwindDataSet(); 
        this.label1.Text = string.Format( " 耗时:{0} ", DateTime.Now - dtBegin); 
        binddata(dataSet); 
    } 
    private void button2_Click( object sender, EventArgs e) 
    { 
        com.dzbsoft.www.Service1 ds = new com.dzbsoft.www.Service1(); 
        DateTime dtBegin = DateTime.Now; 
        byte[] buffer = ds.GetDataSetBytes(); 
        BinaryFormatter ser = new BinaryFormatter(); 
        DataSet dataSet = ser.Deserialize( new MemoryStream(buffer)) as DataSet; 
        this.label2.Text = string.Format( " 耗时:{0} ", DateTime.Now - dtBegin) + "   " + buffer.Length; 
        binddata(dataSet); 
    } 
    private void button3_Click( object sender, EventArgs e) 
    { 
        com.dzbsoft.www.Service1 ds = new com.dzbsoft.www.Service1(); 
        DateTime dtBegin = DateTime.Now; 
        byte[] buffer = ds.GetDataSetSurrogateBytes(); 
        BinaryFormatter ser = new BinaryFormatter(); 
        DataSetSurrogate dss = ser.Deserialize( new MemoryStream(buffer)) as DataSetSurrogate; 
        DataSet dataSet = dss.ConvertToDataSet(); 
        this.label3.Text = string.Format( " 耗时:{0} ", DateTime.Now - dtBegin) + "   " + buffer.Length; 
        binddata(dataSet); 
    } 
    private void button4_Click( object sender, EventArgs e) 
    { 
        com.dzbsoft.www.Service1 ds = new com.dzbsoft.www.Service1(); 
        DateTime dtBegin = DateTime.Now; 
        byte[] zipBuffer = ds.GetDataSetSurrogateZipBytes(); 
        byte[] buffer = UnZipClass.Decompress(zipBuffer); 
        BinaryFormatter ser = new BinaryFormatter(); 
        DataSetSurrogate dss = ser.Deserialize( new MemoryStream(buffer)) as DataSetSurrogate; 
        DataSet dataSet = dss.ConvertToDataSet(); 
        this.label4.Text = string.Format( " 耗时:{0} ", DateTime.Now - dtBegin) + "   " + zipBuffer.Length; 
        binddata(dataSet); 
    } 
    private void binddata(DataSet dataSet) 
    { 
        this.dataGridView1.DataSource = dataSet.Tables[ 0]; 
        this.label5.Text = " 共计: " + dataSet.Tables[ 0].Rows.Count + " 条记录 "
    }
复制代码

在数据返回的方法中,我们使用了数据的压缩,所以,在调用方这边,需要进行解压,代码:

 

复制代码
客户端UnZipClass程序 
    public static class UnZipClass 
    { 
        public static byte[] Decompress( byte[] data) 
        { 
            try 
            { 
                MemoryStream ms = new MemoryStream(data); 
                Stream zipStream = null
                zipStream = new GZipStream(ms, CompressionMode.Decompress); 
                byte[] dc_data = null
                dc_data = ExtractBytesFromStream(zipStream, data.Length); 
                return dc_data; 
            } 
            catch 
            { 
                return null
            } 
        } 
        public static byte[] ExtractBytesFromStream(Stream zipStream, int dataBlock) 
        { 
            byte[] data = null
            int totalBytesRead = 0
            try 
            { 
                while ( true
                { 
                    Array.Resize( ref data, totalBytesRead + dataBlock + 1); 
                    int bytesRead = zipStream.Read(data, totalBytesRead, dataBlock); 
                    if (bytesRead == 0
                    { 
                        break
                    } 
                    totalBytesRead += bytesRead; 
                } 
                Array.Resize( ref data, totalBytesRead); 
                return data; 
            } 
            catch 
            { 
                return null
            } 
        } 
    }
复制代码

在上例中,调用四个方法的效果是一样的,唯一不同的是,传输过程中,数据量大小和传输时间的差异。

目录
相关文章
|
2天前
|
JSON 机器人 数据格式
阿里云RPA支持将序列化的JSON数据作为输入参数传递给机器人应用程序
【1月更文挑战第7天】【1月更文挑战第33篇】阿里云RPA支持将序列化的JSON数据作为输入参数传递给机器人应用程序
212 1
|
2天前
WebService - MEP(信息交换模式)
WebService - MEP(信息交换模式)
31 0
|
12月前
|
前端开发 JavaScript 数据库
(简易)测试数据构造平台:37 - 复杂工具(页面自动获取数据模块后端)
(简易)测试数据构造平台:37 - 复杂工具(页面自动获取数据模块后端)
|
SQL 程序员 数据库
789.【技术】当可选http接口和sql造数据,你会选用哪种方式呢?
789.【技术】当可选http接口和sql造数据,你会选用哪种方式呢?
124 0
|
JSON 缓存 前端开发
【并发技术系列】「Web请求读取系列」如何构建一个可重复读取的Request的流机制
【并发技术系列】「Web请求读取系列」如何构建一个可重复读取的Request的流机制
210 0
【并发技术系列】「Web请求读取系列」如何构建一个可重复读取的Request的流机制
|
存储 XML 缓存
请求合并的 3 种方式,大大提高接口性能。。。
请求合并的 3 种方式,大大提高接口性能。。。
310 0
|
存储 安全 JavaScript
请求合并的 3 种方式,大大提高接口性能!
将相似或重复请求在上游系统中合并后发往下游系统,可以大大降低下游系统的负载,提升系统整体吞吐率。文章介绍了 hystrix collapser、ConcurrentHashMultiset、自实现BatchCollapser 三种请求合并技术,并通过其具体实现对比各自适用的场景。
|
JSON 缓存 测试技术
接口测试平台182:并发用例底层-临时变量替换 URL
接口测试平台182:并发用例底层-临时变量替换 URL
接口测试平台182:并发用例底层-临时变量替换 URL
|
SQL 安全 JavaScript
(简易)测试数据构造平台: 15 (工具列表删除后端)
(简易)测试数据构造平台: 15 (工具列表删除后端)
(简易)测试数据构造平台: 15 (工具列表删除后端)
|
测试技术
接口测试平台插播: 同名字段请求体-其他涉及代码
我们上节课,成功的把单接口调试的底层请求代码中form-data等格式的请求体从字典转变为了多元元组,实现了同名字段的正常请求。本节就来搞定首页请求/用例请求/异常测试/登陆态的底层代码。
接口测试平台插播: 同名字段请求体-其他涉及代码