成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

WCF Stream正確應(yīng)用指南

開(kāi)發(fā) 開(kāi)發(fā)工具
WCF Stream的操作有一定的限制,作為一個(gè)開(kāi)發(fā)人員,在使用的過(guò)程中需要注意這些問(wèn)題。在這里我們將會(huì)針對(duì)這一問(wèn)題進(jìn)行一下詳細(xì)介紹。

WCF是由微軟公司創(chuàng)建的一個(gè).NET Framework 3.5的重要組成部分,它可以為開(kāi)發(fā)人員創(chuàng)建一個(gè)安全性的開(kāi)發(fā)平臺(tái)。WCF Stream的操作,尤其對(duì)于傳遞size過(guò)大的消息而言,如要考慮傳遞消息的效率,WCF推薦通過(guò)Stream進(jìn)行操作。#t#

然而,WCF Stream操作規(guī)定了一些限制,在我們編寫相關(guān)程序時(shí),需要特別注意:

1、綁定的限制

如果需要使用WCF Stream操作,可以使用的綁定只能是BasicHttpBinding,NetTcpBinding以及NetNamedPipeBinding。此外,在使用Stream操作時(shí),不能使用Reliable Messaging。如果考慮到消息安全,則此方式是不可取的。

2、對(duì)Stream對(duì)象的限制

要作為服務(wù)操作所傳遞的消息對(duì)象,這樣的對(duì)象必須是可序列化的。遺憾的是,F(xiàn)ileStream類的定義卻是不支持序列化的,我們能夠使用的Stream對(duì)象,包括Stream,MemoryStream等。使用Stream類對(duì)象是大多數(shù)Stream操作的首選。

一個(gè)有趣的現(xiàn)象是FileStream與Stream類型的轉(zhuǎn)換。例如在服務(wù)契約的操作中,有如下的實(shí)現(xiàn):

  1. public Stream TransferDocument(Document document)  
  2. {  
  3. FileStream stream = new FileStream  
  4. (document.LocalPath, FileMode.Open, FileAccess.Read);  
  5. return stream;  

注意,操作TransferDocument()的返回類型為Stream,而方法的實(shí)現(xiàn)中,返回的對(duì)象則為FileStream類型。由于Stream類是FileStream類的父類,這樣的實(shí)現(xiàn)沒(méi)有問(wèn)題。

然而,在客戶端調(diào)用該操作時(shí),卻不能將操作的返回值賦給FileStream類型的對(duì)象,如下所示:

  1. FileStream stream = m_service.TransferDocument(doc); 

此時(shí)獲得的WCF Stream對(duì)象則為null。因而,我們只能這樣調(diào)用操作:

  1. Stream stream = m_service.TransferDocument(doc); 

但是,還有一個(gè)奇怪的問(wèn)題是WCF并不支持Stream對(duì)象Length屬性的序列化,也就是說(shuō),在客戶端我們不能使用服務(wù)操作返回的Stream對(duì)象的Length屬性。諸如stream.Length的調(diào)用會(huì)拋出NotSupportedException異常。

3、TransferMode的限制

若要使用Stream操作,必須修改綁定的TransferMode屬性。該屬性的默認(rèn)值為Buffered。我們應(yīng)該根據(jù)操作中Stream對(duì)象的參數(shù)類型,以決定TransferMode的值分別為Streamed、StreamedRequest或者StreamedResponse。

4、MaxReceivedMessageSize的限制

MaxReceivedMessageSize屬性的默認(rèn)值為64kb,如果傳遞的Stream對(duì)象一旦超過(guò)了MaxReceivedMessageSize屬性的設(shè)置值,則客戶端在操作該對(duì)象時(shí),就會(huì)出現(xiàn)CommunicationException異常。因此,我們應(yīng)根據(jù)實(shí)際需要設(shè)置MaxReceivedMessageSize的值。MaxReceivedMessageSize屬性的取值范圍為1-9223372036854775807(Int32.MaxValue)。如果設(shè)置值不在該范圍之內(nèi),則無(wú)法通過(guò)編譯。編程方式設(shè)置為:

  1. binding.MaxReceivedMessageSize = 120000

配置文件的設(shè)置方式為:

  1. < binding …… maxReceivedMessageSize="120000"/> 

 

5、操作參數(shù)的限制

WCF Stream的操作參數(shù)進(jìn)行嚴(yán)格的限制,它只允許這樣的操作只能包含一個(gè)Stream對(duì)象,這里所謂的一個(gè)Stream對(duì)象,是包含return對(duì)象,out和ref對(duì)象在內(nèi)的。也就是說(shuō)如下的操作定義都是錯(cuò)誤的:

  1. void Transfer(Stream s1, Stream s2);  
  2. void Transfer(Stream s1, out Stream s2);  
  3. void Transfer(Stream s1, ref Stream s2);  
  4. Stream Transfer(Stream stream); 

如果定義了這樣的操作,則會(huì)出現(xiàn)運(yùn)行時(shí)錯(cuò)誤。

6、實(shí)例激活類型的限制

由于Stream操作受到綁定的限制,只能使用BasicHttpBinding,NetTcpBinding以及NetNamedPipeBinding綁定,因此必然會(huì)影響服務(wù)實(shí)例的激活類型,最主要的是對(duì)Session模式的影響。首先BasicHttpBinding并不支持Session模式的激活類型。NetTcpBinding以及NetNamedPipeBinding綁定雖然支持Session模式,但是由于Stream操作不支持可靠消息傳遞,即不能將ReliableSession設(shè)置為true。因此在定義服務(wù)契約的SessionMode時(shí),不能將其值設(shè)置為SessionMode.Required,否則會(huì)拋出異常。

實(shí)際上,Stream操作(指TransferMode不為Buffered)本身并不支持Session模式。即使我們?cè)谑褂肗etTcpBinding時(shí),將服務(wù)契約的SessionMode設(shè)置為Allowed,并將服務(wù)的InstanceContextMode設(shè)置為PerSession,服務(wù)的執(zhí)行方式仍然是PerCall方式。(如果不是Stream操作,這樣的設(shè)置服務(wù)應(yīng)為PerSession模式)

因此,在執(zhí)行WCF Stream操作時(shí),即使按照Session模式對(duì)服務(wù)進(jìn)行設(shè)置,如果我們通過(guò)OperationContext.Current.SessionId去獲得會(huì)話ID,其值應(yīng)該為空。

此外,由于傳輸?shù)腟tream對(duì)象較大,可能會(huì)消耗過(guò)長(zhǎng)的時(shí)間,因而建議增大綁定的SendTimeout屬性值。例如設(shè)置為10分鐘。編程方式設(shè)置為:

  1. binding.SendTimeout = TimeSpan.FromMinutes(10); 

配置文件的設(shè)置方式為:

  1. < binding …… sendTimeout="00:10:00"/> 

注意,對(duì)綁定的相關(guān)設(shè)置必須要求服務(wù)端與客戶端的配置一致。最佳實(shí)踐是均通過(guò)配置文件進(jìn)行設(shè)置。例如在我的應(yīng)用程序中是這樣設(shè)置的:

  1. < basicHttpBinding> 
  2. < binding name="DocumentExplorerServiceBinding"   
  3. sendTimeout="00:10:00"   
  4. transferMode="Streamed" 
  5. messageEncoding="Text"   
  6. textEncoding="utf-8"   
  7. maxReceivedMessageSize="9223372036854775807">   
  8. < /binding> 
  9. < /basicHttpBinding> 

以上就是對(duì)WCF Stream的相關(guān)操作方法。

責(zé)任編輯:曹凱 來(lái)源: 博客園
相關(guān)推薦

2010-02-22 14:09:08

WCF Dispose

2010-05-28 15:16:40

MySQL 資源

2009-12-07 14:38:14

PHP foreach

2010-05-25 18:01:35

linux MySQL

2010-05-28 19:20:36

MySQL mysql

2010-07-21 10:50:48

SQL Server存

2010-07-26 17:43:34

SQL Server

2010-02-05 17:49:24

C++常量引用

2010-02-05 14:12:46

C++聲明放置

2010-03-04 13:30:11

Python file

2010-03-04 09:40:52

Python Clas

2021-07-02 16:13:01

區(qū)塊鏈金融數(shù)據(jù)庫(kù)

2010-02-01 15:26:44

C++ inline函

2010-03-05 15:01:29

Python解析XML

2010-03-03 17:58:16

Python同步隊(duì)列

2010-08-18 16:45:40

IBM DB2 Cat

2010-01-25 11:29:33

Android計(jì)時(shí)器

2010-03-03 17:33:52

Python讀取XML

2010-03-04 14:02:51

Python大小寫

2010-07-26 16:11:45

Microsoft S
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 国产亚洲精品美女久久久久久久久久 | 久久久久久色 | 日本天天色 | 久久久做 | 九热在线 | 在线观看视频91 | 狠狠干天天干 | 久久久久成人精品免费播放动漫 | 在线亚洲人成电影网站色www | 精品av天堂毛片久久久借种 | 国产激情精品视频 | 久久综合久久久 | 欧美成年黄网站色视频 | 国产一区二区三区四区在线观看 | 涩爱av一区二区三区 | 精品视频一区二区 | 久久精品国产99国产精品亚洲 | 成人h片在线观看 | 亚洲一区二区三区免费在线观看 | 亚洲精品一区二区三区免 | 国产高清精品一区二区三区 | 欧美精品91 | 中文一区二区 | 久久久久亚洲 | 国产激情视频在线观看 | 欧美精品久久久久久久久久 | 夜操 | 午夜性色a√在线视频观看9 | 久久剧场| 亚洲国产一区二区三区 | 亚洲精品视频久久 | 色综合天天综合网国产成人网 | 一本久久a久久精品亚洲 | 国产成人精品视频在线观看 | 亚洲精品在线观看网站 | 青青草精品视频 | 日皮视频免费 | 日韩精品一区二区三区 | 欧美区在线 | 亚洲免费一区二区 | 精品国产免费一区二区三区五区 |