Udostępnij za pośrednictwem


SdlChannelSink.ProcessMessage Metoda

Definicja

Żąda przetwarzania komunikatów z bieżącego ujścia.

public:
 virtual System::Runtime::Remoting::Channels::ServerProcessing ProcessMessage(System::Runtime::Remoting::Channels::IServerChannelSinkStack ^ sinkStack, System::Runtime::Remoting::Messaging::IMessage ^ requestMsg, System::Runtime::Remoting::Channels::ITransportHeaders ^ requestHeaders, System::IO::Stream ^ requestStream, [Runtime::InteropServices::Out] System::Runtime::Remoting::Messaging::IMessage ^ % responseMsg, [Runtime::InteropServices::Out] System::Runtime::Remoting::Channels::ITransportHeaders ^ % responseHeaders, [Runtime::InteropServices::Out] System::IO::Stream ^ % responseStream);
public System.Runtime.Remoting.Channels.ServerProcessing ProcessMessage (System.Runtime.Remoting.Channels.IServerChannelSinkStack sinkStack, System.Runtime.Remoting.Messaging.IMessage requestMsg, System.Runtime.Remoting.Channels.ITransportHeaders requestHeaders, System.IO.Stream requestStream, out System.Runtime.Remoting.Messaging.IMessage responseMsg, out System.Runtime.Remoting.Channels.ITransportHeaders responseHeaders, out System.IO.Stream responseStream);
abstract member ProcessMessage : System.Runtime.Remoting.Channels.IServerChannelSinkStack * System.Runtime.Remoting.Messaging.IMessage * System.Runtime.Remoting.Channels.ITransportHeaders * System.IO.Stream * IMessage * ITransportHeaders * Stream -> System.Runtime.Remoting.Channels.ServerProcessing
override this.ProcessMessage : System.Runtime.Remoting.Channels.IServerChannelSinkStack * System.Runtime.Remoting.Messaging.IMessage * System.Runtime.Remoting.Channels.ITransportHeaders * System.IO.Stream * IMessage * ITransportHeaders * Stream -> System.Runtime.Remoting.Channels.ServerProcessing
Public Function ProcessMessage (sinkStack As IServerChannelSinkStack, requestMsg As IMessage, requestHeaders As ITransportHeaders, requestStream As Stream, ByRef responseMsg As IMessage, ByRef responseHeaders As ITransportHeaders, ByRef responseStream As Stream) As ServerProcessing

Parametry

sinkStack
IServerChannelSinkStack

Stos ujściów kanału, który nazwał bieżący ujście.

requestMsg
IMessage

Komunikat zawierający żądanie.

requestHeaders
ITransportHeaders

Nagłówki pobierane z komunikatu przychodzącego z klienta.

requestStream
Stream

Strumień, który należy przetworzyć i przekazać do ujścia deserializacji.

responseMsg
IMessage

Gdy ta metoda zwróci wartość , zawiera IMessage komunikat z odpowiedzią. Ten parametr jest przekazywany jako niezainicjowany.

responseHeaders
ITransportHeaders

Gdy ta metoda zwraca wartość , zawiera nagłówek ITransportHeaders , który zawiera nagłówki, które mają zostać dodane w celu zwrócenia nagłówka komunikatu do klienta. Ten parametr jest przekazywany jako niezainicjowany.

responseStream
Stream

Gdy ta metoda zostanie zwrócona, zawiera Stream nagłówek kierujący do ujścia transportu. Ten parametr jest przekazywany jako niezainicjowany.

Zwraca

ServerProcessing Wartość stanu, która zawiera informacje o sposobie przetwarzania komunikatu.

Implementuje

Uwagi

Zadanie serwera proxy polega na przekonwertowaniu wywołania metody wywoływanego na nim do obiektu komunikatu. Obiekt Message, który implementuje IMessage interfejs, jest przekazywany z końca klienta do serwera przez wywołanie ProcessMessage obiektów ujścia komunikatów. Ujścia komunikatów są połączone w łańcuch, co oznacza, że każde ujście komunikatu jest odpowiedzialne za wywołanie ProcessMessage następnego ujścia komunikatu po wykonaniu jego pracy. Na przykład ujście komunikatów związanych z synchronizacją może spowodować uzyskanie lub zwolnienie blokady i delegowanie do ujścia komunikatu podrzędnego.

Gdy ujście kanału formatującego pobiera komunikat, który musi zostać wysłany za pośrednictwem kanału, wywołuje SyncProcessMessagemetodę , przekazując komunikat jako parametr. Ujście formatującego tworzy następnie tablicę nagłówków transportu i wywołuje GetRequestStream ujście formatującego. To wywołanie jest przekazywane w dół łańcucha ujścia, a każdy ujście może utworzyć strumień żądania, który jest przekazywany z powrotem do ujścia formatującego. Po powrocie tego wywołania komunikat jest serializowany, ProcessMessage jest wywoływany w pierwszym łańcuchu ujścia, a komunikat jest przekazywany do ujść kanału.

Po otrzymaniu komunikatu ujścia kanału mogą zapisywać dane w strumieniu, dodawać nagłówki do tablicy nagłówków i dodawać się do stosu ujścia przed przekazaniem wywołania do następnego ujścia. Gdy wywołanie dociera do ujścia transportu na końcu łańcucha, ujście transportu wysyła nagłówki i serializowany komunikat przez kanał do serwera, gdzie proces jest odwrócony.

Gdy komunikat dociera po stronie serwera, ujście transportu pobiera nagłówki i serializowany komunikat ze strumienia i przekazuje je do łańcucha ujścia do momentu osiągnięcia ujścia formatującego. Ujście formatującego następnie deserializuje komunikat i przekazuje go do komunikacji telefonicznej, gdzie komunikat jest zamieniany w wywołanie metody, a obiekt serwera jest wywoływany.

Dotyczy