浅谈WebService返回数据效率对比

原文链接 http://www.dotnetgeek.cn/xuexiwebservice1.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作为根本,然后来做各种转换压缩的操作:

1 [WebMethod(Description = "直接返回DataSet对象")]  
 2     public DataSet GetDataSet()  
 3     {  
 4         string connStr = System.Configuration.ConfigurationManager.ConnectionStrings["conn"].ToString();  
 5         SqlConnection conn = new SqlConnection(connStr);  
 6         string sql = "select * from china_city";  
 7         conn.Open();  
 8         SqlDataAdapter sda = new SqlDataAdapter(sql, conn);  
 9         DataSet ds = new DataSet("China");  
10         sda.Fill(ds);  
11         conn.Close();  
12         return ds;  
13     }  
14   
15     [WebMethod(Description = "直接返回DataSet对象,并用Binary序列化后的字节数组")]  
16     public byte[] GetDataSetBytes()  
17     {  
18         DataSet ds = GetDataSet();  
19         BinaryFormatter ser = new BinaryFormatter();  //序列化对象  
20         MemoryStream ms = new MemoryStream();  //内存流  
21         ser.Serialize(ms, ds);  
22         byte[] buffer = ms.ToArray();    //字节流  
23         return buffer;  
24     }  
25   
26     [WebMethod(Description = "直接返回DataSetSurrogate对象,并用Binary序列化后的字节数组")]  
27     public byte[] GetDataSetSurrogateBytes()  
28     {  
29         DataSet ds = GetDataSet();  
30         DataSetSurrogate dss = new DataSetSurrogate(ds);  
31         BinaryFormatter ser = new BinaryFormatter();  //序列化对象  
32         MemoryStream ms = new MemoryStream();  //内存流  
33         ser.Serialize(ms, dss);  
34         byte[] buffer = ms.ToArray();    //字节流  
35         return buffer;  
36   
37     }  
38   
39     [WebMethod(Description = "直接返回DataSetSurrogate对象,并用Binary序列化后并且ZIP压缩的字节数组")]  
40     public byte[] GetDataSetSurrogateZipBytes()  
41     {  
42         DataSet ds = GetDataSet();  
43         DataSetSurrogate dss = new DataSetSurrogate(ds);  
44         BinaryFormatter ser = new BinaryFormatter();  //序列化对象  
45         MemoryStream ms = new MemoryStream();  //内存流  
46         ser.Serialize(ms, dss);  
47         byte[] buffer = ms.ToArray();    //字节流  
48         byte[] bufferZip = ComPress(buffer);  
49         return buffer;  
50     }  
51     //压缩方法  
52     public byte[] ComPress(byte[] data)  
53     {  
54         try  
55         {  
56             MemoryStream ms = new MemoryStream();  
57             Stream zipStream = null;  
58             zipStream = new GZipStream(ms, CompressionMode.Compress, true);  
59             zipStream.Write(data, 0, data.Length);  
60             zipStream.Close();  
61             ms.Position = 0;  
62             byte[] compressed_data = new byte[ms.Length];  
63             ms.Read(compressed_data, 0, int.Parse(ms.Length.ToString()));  
64             return compressed_data;  
65         }  
66         catch  
67         {  
68             return null;  
69         }  
70     }

我们可以在浏览器中查看下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;  
            }  
        }  
    }

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

时间: 2024-10-03 15:36:00

浅谈WebService返回数据效率对比的相关文章

浅谈WebService SOAP、Restful、HTTP(post/get)请求

HTTP-GET 和 HTTP-POST HTTP-GET和HTTP-POST是标准协议,他们使用HTTP(超文本传输协议)谓词(谓词是指条件表达式的求值返回真或假的过程.)对参数进行编码并将参数作为名称/值对传递,还使用关联的请求语义.每个协议都包含一系列HTTP请求标头,HTTP请求标头及其他一些信息定义客户端向服务器请求哪些内容,哪个服务器用一系列HTTP响应标头和所请求的数据进行响应. HTTP-GET 使用 MIME 类型 application/x-www-form-urlencod

JQuery请求WebService返回数据的几种处理方式

打开自己的博客仔细浏览了一番,发现已经好久没有写博客了,由于最近一直比较忙碌懈怠了好多.默默反省三分钟.......言归正传,现在就对最近在学习webservice的过程中遇到的几种类型的问题中我的理解和解决方案.对于webservice大家肯定知道,它是一种使不同站点之间可以相互通信的技术,可以理解为一种接口.一个站点可以通过其它站点提供的webservice接口获得其它站点提供的相应服务.webservice使用起来非常小巧,轻便被很多站点所使用.对于webservice我不做过多说明,we

浅谈WebService开发(一)转

一.什么是WebService: 简单通俗来说,就是企业之间.网站之间通过Internet来访问并使用在线服务,一些数据,由于安全性问题,不能提供数据库给其他单位使用,这时候可以使   用WebService服务提供. 二.创建WebService 创建WebService之后,我们就可以在文件里写返回数据的方法了. 三.返回数据的四种形式 笔者水平有限,只列出这四种数据的返回形式: (1)直接返回DataSet对象  (2)返回DataSet对象用Binary序列化后的字节数组  (3)返回D

浅谈My SQL引擎的对比

MySQL数 据库引擎取决于MySQL在安装的时候是如何被编译的.要添加一个新的引擎,就必须重新编译MYSQL.在缺省情况下,MYSQL支持三个引擎:ISAM.MYISAM和HEAP.另外两种类型INNODB和BERKLEY(BDB),也常常可以使用.如果技术高超,还可以使用MySQL++ API自己做一个引擎.下面介绍几种数据库引擎:     ISAM:ISAM是一个定义明确且历经时间考验的数据表格管理方法,它在设计之时就考虑到 数据库被查询的次数要远大于更新的次数.因此,ISAM执行读取操作

[转] - 浅谈数据分析和数据建模

大数据应用有几个方面,一个是效率提升,帮助企业提升数据处理效率,降低数据存储成本.另外一个是对业务作出指导,例如精准营销,反欺诈,风险管理以及业务提升.过去企业都是通过线下渠道接触客户,客户数据不全,只能利用财务数据进行业务运营分析,缺少围绕客户的个人数据,数据分析应用的领域集中在企业内部经营和财务分析. 数字时代到来之后,企业经营的各个阶段都可以被记录下来,产品销售的各个环节也被记录下来,客户的消费行为和网上行为都被采集下来.企业拥有了多维度的数据,包括产品销售数据.客户消费数据.客户行为数据

Android批量插入数据效率对比

1.一个一个插入 /** * 向表中插入数据 * * @param openHelper * @param appInfo * @return */ public static boolean insert(SQLiteOpenHelper openHelper, RemoteAppInfo appInfo) { if (null == appInfo) { return true; } SQLiteDatabase db = null; try { db = openHelper.getWri

Oracle 插入数据效率对比

oracle插入数据有多种方式: 将从多个表中查出来的数据插入到临时表中 数据行数 5189597 1.传统方式:直接将数据插入到表中 1 insert into LLB_BASIC_USER_D_TEMP_TEST 2 select t.serv_id, 3 t.phone_id, 4 a1.loc_imei t, 5 region_code, 6 t.county_code, 7 t.payment_mode_cd, 8 t.plan_id, 9 t.productflux, 10 t.al

浅谈金融大数据

金融大数据的行业影响金融大数据在金融行业的应用能有效的帮助金融行业实现信息化转型,使得金融行业整体更为高效. 金融大数据的行业影响 金融大数据在金融行业的应用能有效的帮助金融行业实现信息化转型,使得金融行业整体更为高效. 金融大数据的帮助下,金融信息将会以更多的方式呈现.借助大数据可视化技术,结构化和非结构化数据可以从大量的金融信息之中提取出最有用的数据,并且用最合适的方式呈现,让用户可以从更多的角度和价值模型之中获益,帮助用于金融研究以及决策.金融大数据可视化还可以提供经济分析.管理分析以及绩

浅谈 JS 的数据遍历的几种方式

遍历对象(数组)是我们日常撸码的必不可少的部分,如何从性能上优化代码,提高运行效率?下文为你揭开真像: 第一种:普通的for循环 for(j = 0; j < arr.length; j++) { } 简要说明:最简单的一种,也是使用频率最高的一种,性能不弱,但是有优化空间 第二种:优化过的for循环(性能最高) for(j = 0,len=arr.length; j < len; j++) { } 简要说明:使用临时变量,将长度缓存起来,避免重复获取长度,当数组较大时优化效果才会比较明显.这