Niestandardowe uaktualnienia strumienia

Transporty zorientowane na strumień, takie jak TCP i nazwane potoki, działają na ciągłym strumieniu bajtów między klientem a serwerem. Ten strumień jest zrealizowany Stream przez obiekt. W ramach uaktualnienia strumienia klient chce dodać opcjonalną warstwę protokołu do stosu kanału i prosi o to inny koniec kanału komunikacyjnego. Uaktualnienie strumienia polega na zastąpieniu oryginalnego Stream obiektu uaktualnionym.

Można na przykład utworzyć strumień kompresji bezpośrednio na strumieniu transportu. W takim przypadku oryginalny transport Stream jest zastępowany jednym, który owija kompresję Stream wokół oryginalnego.

Można zastosować wiele uaktualnień strumieni, z których każdy opakowuje poprzednie.

Jak działają uaktualnienia strumienia

Proces uaktualniania strumienia zawiera cztery składniki.

  1. Inicjator strumienia uaktualnienia rozpoczyna proces: w czasie wykonywania może zainicjować żądanie na drugim końcu połączenia w celu uaktualnienia warstwy transportu kanału.

  2. Akceptowanie strumienia uaktualnienia wykonuje uaktualnienie: w czasie wykonywania odbiera żądanie uaktualnienia z innej maszyny, a jeśli to możliwe, akceptuje uaktualnienie.

  3. Dostawca uaktualniania tworzy inicjatora na kliencie i elementy akceptujące na serwerze.

  4. Element powiązania uaktualnienia strumienia jest dodawany do powiązań usługi i klienta oraz tworzy dostawcę w czasie wykonywania.

Należy pamiętać, że w przypadku wielu uaktualnień inicjator i akmetyzator hermetyzują maszyny stanu, aby wymusić, które przejścia uaktualnienia są prawidłowe dla każdej inicjacji.

Jak zaimplementować uaktualnienie strumienia

Program Windows Communication Foundation (WCF) udostępnia cztery abstract klasy, które można zaimplementować:

Aby zaimplementować niestandardowe uaktualnienie strumienia, wykonaj następujące czynności. Ta procedura implementuje minimalny proces uaktualniania strumienia na komputerach klienckich i serwerowych.

  1. Utwórz klasę, która implementuje StreamUpgradeInitiator.

    1. Zastąpij metodę InitiateUpgrade , aby przejąć strumień do uaktualnienia i zwrócić uaktualniony strumień. Ta metoda działa synchronicznie; Istnieją analogiczne metody inicjowania uaktualnienia asynchronicznie.

    2. Zastąpij metodę GetNextUpgrade , aby sprawdzić dodatkowe uaktualnienia.

  2. Utwórz klasę, która implementuje StreamUpgradeAcceptor.

    1. Zastąpij metodę AcceptUpgrade , aby przejąć strumień do uaktualnienia i zwrócić uaktualniony strumień. Ta metoda działa synchronicznie; Istnieją analogiczne metody akceptowania uaktualnienia asynchronicznie.

    2. Zastąpi metodę CanUpgrade w celu określenia, czy żądane uaktualnienie jest obsługiwane przez ten akceptowany uaktualnienia w tym momencie w procesie uaktualniania.

  3. Utwórz klasę implementuje StreamUpgradeProviderelement . Zastąpij CreateUpgradeAcceptor metody i CreateUpgradeInitiator , aby zwracać wystąpienia akceptowania i inicjatora zdefiniowane w krokach 2 i 1.

  4. Utwórz klasę, która implementuje StreamUpgradeBindingElement.

    1. Zastąpi metodę BuildClientStreamUpgradeProvider na kliencie i BuildServerStreamUpgradeProvider metodę w usłudze.

    2. Zastąpij metodę BuildChannelFactory na kliencie i BuildChannelListener metodę w usłudze, aby dodać element powiązania uaktualnienia do BindingParameterselementu .

  5. Dodaj nowy element powiązania uaktualnienia strumienia do powiązań na serwerze i maszynach klienckich.

Uaktualnienia zabezpieczeń

Dodanie uaktualnienia zabezpieczeń to wyspecjalizowana wersja ogólnego procesu uaktualniania strumienia.

Program WCF udostępnia już dwa elementy powiązania na potrzeby uaktualniania zabezpieczeń strumienia. Konfiguracja zabezpieczeń na poziomie transportu jest hermetyzowana przez WindowsStreamSecurityBindingElement element i SslStreamSecurityBindingElement , który można skonfigurować i dodać do powiązania niestandardowego. Te elementy powiązania rozszerzają klasę StreamUpgradeBindingElement , która kompiluje dostawców uaktualnienia klienta i strumienia serwera. Te elementy powiązania mają metody, które tworzą wyspecjalizowane klasy dostawcy uaktualniania strumienia zabezpieczeń, które nie publicsą , więc w tych dwóch przypadkach wystarczy dodać element powiązania do powiązania.

W przypadku scenariuszy zabezpieczeń, które nie zostały spełnione przez powyższe dwa elementy powiązania, trzy klasy związane z abstract zabezpieczeniami pochodzą z powyższych klas inicjatora, akceptowania i klas bazowych dostawcy:

  1. System.ServiceModel.Channels.StreamSecurityUpgradeInitiator

  2. System.ServiceModel.Channels.StreamSecurityUpgradeAcceptor

  3. System.ServiceModel.Channels.StreamSecurityUpgradeProvider

Proces implementowania uaktualnienia strumienia zabezpieczeń jest taki sam jak poprzednio, z różnicą, która wynika z tych trzech klas. Zastąpi dodatkowe właściwości w tych klasach, aby dostarczyć informacje o zabezpieczeniach do środowiska uruchomieniowego.

Wiele uaktualnień

Aby utworzyć dodatkowe żądania uaktualnienia, powtórz powyższy proces: utwórz dodatkowe rozszerzenia StreamUpgradeProvider elementów i powiązania. Dodaj elementy powiązania do powiązania. Dodatkowe elementy powiązania są przetwarzane sekwencyjnie, począwszy od pierwszego elementu powiązania dodanego do powiązania. W BuildChannelFactory programie i BuildChannelListener każdy dostawca uaktualnienia może określić, jak warstwować się na dowolnych wstępnie istniejących parametrów powiązania uaktualnienia. Następnie należy zastąpić istniejący parametr powiązania uaktualnienia nowym parametrem powiązania uaktualnienia złożonego.

Alternatywnie jeden dostawca uaktualnienia może obsługiwać wiele uaktualnień. Możesz na przykład zaimplementować niestandardowego dostawcę uaktualnienia strumienia, który obsługuje zarówno zabezpieczenia, jak i kompresję. Wykonaj poniższe kroki:

  1. Podklasa StreamSecurityUpgradeProvider do zapisu klasy dostawcy, która tworzy inicjator i acceptor.

  2. Podklasa StreamSecurityUpgradeInitiator upewniając się, że zastąpisz metodę GetNextUpgrade , aby zwrócić typy zawartości strumienia kompresji i bezpieczny strumień w kolejności.

  3. Podklasa StreamSecurityUpgradeAcceptor , która rozumie niestandardowe typy zawartości w swojej CanUpgrade metodzie.

  4. Strumień zostanie uaktualniony po każdym wywołaniu metody GetNextUpgrade i CanUpgrade.

Zobacz też