Channel,Sink,SinkChainandChannelSinkProvider為了擴展.NetRemoting,定制接收器(" />

亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

信道、接收器、接收鏈和信道接受提供程序

系統 2088 0
<iframe align="center" marginwidth="0" marginheight="0" src="http://www.zealware.com/csdnblog336280.html" frameborder="0" width="336" scrolling="no" height="280"></iframe>

Channel, Sink, Sink Chain and Channel Sink Provider

為了擴展 .Net Remoting ,定制接收器( Sink )和信道接受提供程序( Channel Sink Provider ),改變 .Net Remoting 的缺省行為,需要先了解 .Net Remoting 的相關概念及其運行機制。

下面先了解一些基本概念:

信道( Channel -是跨遠程處理邊界(無論是在應用程序域、進程還是計算機之間)在應用程序之間傳輸消息的對象。信道可以在終結點上偵聽入站消息,向另一個終結點發送出站消息,或者兩者都可以。

信道必須實現 IChannel 接口,該接口提供諸如 ChannelName ChannelPriority 這樣的屬性。專用于在特定端口上偵聽特定協議的信道實現 IChannelReceiver ,而專用于發送信息的信道實現 IChannelSender (注: IChannelReceiver IChannelSender 接口都繼承 IChannel 接口)。 TcpChannel HttpChannel 對象都實現這兩種接口,因此它們可用于發送或接收信息。

.Net Remoting Framework 提供了 TcpChannel HttpChannel 兩個信道的實現。

在發送消息之前或接收消息之后,信道( Channel )沿著信道接收對象鏈( a chain of channel sink objects )發送每個消息。該接收鏈( sink chain )包含基本信道功能所需的 接收器( Sink (如格式化程序接收器 FormatterSink 、傳輸接收器 TransportSink 或堆棧生成器接收器 StackBuilderSink ),但是您可以自定義信道接收鏈以便用消息或流執行特殊任務。

信道接收鏈( Sink Chain 處理任何發送到應用程序域或從應用程序域發送的消息。此時,您只有消息,但是您可以任意操作該消息,而后面的處理將使用您在處理之后返回給系統的消息。這是實現日志記錄服務、任何種類的篩選器或者客戶端或服務器上的加密或其他安全措施的理所當然的位置。以下插圖顯示基本信道接收鏈的結構。


信道、接收器、接收鏈和信道接受提供程序

每個 信道接收器( Channel Sink 都處理流,然后將流傳遞到下一個信道接收器,這意味著您的接收器之前或之后的對象應當知道該如何處理傳遞給它們的流。( Sink/Channel Sink 是同一個描述。)

StackBuilderSink 對象是服務器上遠程對象前的最后一個消息接收器。

每個信道接收器( Channel Sink )或者實現 IClientChannelSink ,或者實現 IServerChannelSink ??蛻舳松系牡谝粋€信道接收器還必須實現 IMessageSink 。它通常實現 IClientFormatterSink (它從 IMessageSink 、 IChannelSinkBase IClientChannelSink 繼承),并被稱作格式化程序接收器( Formatter Sink ),因為它將傳入的消息轉換為流( IMessage 對象)。

信道接收提供程序( Channel Sink Provider -(實現 IClientChannelSinkProvider 、 IClientFormatterSinkProvider IServerChannelSinkProvider 接口的對象)負責創建遠程處理消息所流過的信道接收器( Channel Sink )。當遠程類型被激活后,將從信道( Channel )中檢索信道接收提供程序( Channel Sink Provider );然后在該接收提供程序上調用 CreateSink 方法以檢索鏈上的接收器中的第一個 Sink 。

信道接收器( Channel Sink )還負責在客戶端和服務器之間傳輸消息。信道接收器也鏈接在一起而形成一個鏈。當在接收提供程序上調用 CreateSink 方法時,該方法應該執行以下操作:

· 創建它自己的信道接收器。

· 在鏈中的下一個接收提供程序上調用 CreateSink 。

· 確保下一個接收器和當前的接收器鏈接在一起。

· 將其接收器返回到調用方。

信道接收器負責將在它們上面進行的所有調用轉發到鏈中的下一個接收器,并且應當提供用于存儲對下一個接收器的引用的機制。

自定義信道接收器( Custom Channel Sinks

自定義信道接收器被插入到格式化程序接收器( FormatterSink )和最后一個傳輸接收器( TransportSink )之間的對象鏈中。

傳輸接收器( TransportSink

傳輸接收器是客戶端上的鏈中最后一個接收器和服務器端上的鏈中第一個接收器。除了傳輸序列化的消息,傳輸接收器還負責將標頭( Header )發送到服務器并在調用從服務器返回時檢索標頭和流。這些接收器內置在信道中,并且無法擴展。

簡要總結 .Net Remoting Infrastructure 機制:

1 ,代理對象( Proxy )負責轉發對 Remote Objects 的調用。

2 ,消息對象( Message Objects )用來調用 Remote Methods 的數據。

3 ,信道接收器( Sink/Channel Sink )用來遠程方法調用( Remote method calls )處理消息。

4 ,信道接收提供程序( Channel Sink Provider )-一般用來將接收器( Sink )插入到信道接收鏈( Sink Chain )中。

5 ,格式化程序接收器 FormatterSink -用來序列化 / 反序列化消息格式,進行傳遞。

6 ,傳輸接收器 TransportSink -用來在進程或 AppDomain 之間傳遞序列化的消息。

Reference:

1, MSDN, .NET Framework 開發員指南 , 接收器和接收鏈




信道、接收器、接收鏈和信道接受提供程序


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!??!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 性夜影院爽黄a爽免费看网站 | 日韩成人精品在线 | 青青操网址 | 五月伊人 | 最近中文字幕免费版在线3 最近中文字幕无吗高清视频 | 午夜大片免费男女爽爽影院久久 | www.香蕉视频| 久久人人爽人人爽 | 亚洲最大激情网 | 日日碰碰 | 国产欧美视频一区二区三区 | 伊人久久91 | 久久青草91免费观看 | 亚洲精品女同中文字幕在线 | 高清亚洲 | 四虎国产精品永久地址99新强 | 日韩精品你懂的在线播放 | 久久国产精品亚洲77777 | 99久热国产精品视频尤物不卡 | 国产成人高清视频免费播放 | 夜夜操com | 国产在线成人精品 | 欧美日本一道免费一区三区 | 亚洲啪视频| 国产精品视频第一区二区 | 刺激videoschina偷拍 | 久久天天躁狠狠躁夜夜爽 | 欧美成人高清免费大片观看 | 亚洲qingse中文久久网 | 91视频入口 | 天天操夜夜添 | 四虎在线精品免费高清在线 | 深夜在线观看网站 | 日本精品一区二区三区视频 | 天天摸天天碰色综合网 | 亚洲成人福利 | 青青青免费视频精品99 | 欧美天天干| 又黑又粗又硬欧美视频在线观看 | 99pao在线视频精品免费 | 国产永久在线 |